1、题目一:计算出现次数和位置
1.1 问题描述
编写程序统计一个字符子串在一个字符串中出现的次数和位置。如子字符串“nba”在字符串”asfasfnabaasdfnbasdnbasnbasdnbadfasdf”中出现的次数和出现的位置。
1.2 解题思路
需要运用到String类的几个常用方法
indexOf(ch) //用于返回指定子串“ch”在字符串中第一次出现的位置
contains() //用于判断字符串中是否包含指定的字符或字符串。
substring(int beginIndex) //用于返回新字符串,包含一个参数beginIndex,表示从beginIndex开始到结尾结束
具体使用方法见代码
1.3 运行代码
public class wmj4_1 {
//创建寻找出现次数和出现位置的函数,导入参数字符串和要寻找的字符
public static void main(String[] args){
String str="asfasfnabaasdfnbasdnbasnbasdnbadfasdf";
String key="nba"; //需要查找的子串
int count=1; //出现的次数
int index,index1=0; //下标
int n=1; //用于显示每次出现
//首先判断子串是否在字符串中
if(str.contains(key)){
//如果下标等于第一次出现的子串,并且不等于-1
while((index=str.indexOf(key))!=-1){
//返回一个新字符串,从找到的第一个子串后开始到结束
str=str.substring(index+key.length());
//输出当前的位置
System.out.println("第"+(n++)+"次出现的位置是:"+(index+index1));
index1=(index+index1+key.length()); //因为substring会返回新的列表,用index1来记录原来的下标
count++;
}
}
System.out.println("统计:字符串nba一共出现了"+count+"次");
}
}
1.4 运行结果
第1次出现的位置是:14
第2次出现的位置是:19
第3次出现的位置是:23
第4次出现的位置是:28
统计:字符串nba一共出现了5次
如果不保存原来的下标操作,结果会是这样的:
2、题目而:计算出现次数和位置
2.1 问题描述
对字符串“23 10 -8 0 3 7 108”中的数值进行升序排序,生成一个数值有序的字符串 “-8 0 3 7 10 23 208”。
2.2 解题思路
需要运用到StringBuilder类的几个常用方法
具体使用方法见代码
2.3 运行代码
import java.util.Arrays;
public class wmj4_2 {
private static final String SEPARATOR=" ";
public static void main(String[] args){
String numstr="23 10 -8 0 3 7 108";
String numstrs=SortNumberString(numstr);
System.out.println(numstrs);
}
private static String SortNumberString(String numstr) {
//将字符串转换为多个数字格式的字符串数组
String[] numbers=toStringArray(numstr);
int[] numint=toIntArray(numbers);
sort(numint);
return toString(numint);
}
private static String toString(int[] numint){
StringBuilder sb=new StringBuilder();
for(int i=0;i<numint.length;i++){
//判断是否为最后一行
if(i!=numint.length-1){
sb.append(numint[i]+SEPARATOR);
}
else{
sb.append(numint[i]);
}
}
return sb.toString();
}
private static void sort(int[] numint){
Arrays.sort(numint);
}
private static int[] toIntArray(String[] numbers){
int[] numint=new int[numbers.length];
for(int i=0;i<numbers.length;i++){
numint[i]=Integer.parseInt(numbers[i]);
}
return numint;
}
private static String[] toStringArray(String numstr){
return numstr.split(SEPARATOR);
}
}
2.4 运行结果
-8 0 3 7 10 23 108
2、题目而:计算出现次数和位置
3.1 问题描述
对字符串“23 10 -8 0 3 7 108”中的数值进行升序排序,生成一个数值有序的字符串 “-8 0 3 7 10 23 208”。
3.2 解题思路
需要运用到StringBuilder类的几个常用方法
具体使用方法见代码
3.3 运行代码
import java.io.IOException;
import java.util.*;
import java.util.Scanner;
public class wmj4_3 {
public static void main(String[] args){
//输入
Scanner sc=new Scanner(System.in);
//获取当前系统属性
Properties pp=System.getProperties();
//获取当前应用程序的运行环境对象
Runtime rt=Runtime.getRuntime();
String tmp=null;
while(true){
System.out.println("请选择操作 【请用大写字母】:");
System.out.println("*************************************");
System.out.println("A:记事本");
System.out.println("B:重启计算机");
System.out.println("C:启动QQ");
System.out.println("D:查看系统操作");
System.out.println("G:退出");
tmp=sc.next();
if(tmp.equals("A")){
try{
rt.exec("notepad.exe");
}catch(IOException e){
e.printStackTrace();
}
}
else if(tmp.equals("B")){
try{
rt.exec("shutdown -r");
}catch(IOException e){
e.printStackTrace();
}
}
else if(tmp.equals("C")){
try{
rt.exec("D:\\Program Files\\tencent\\QQ\\Bin\\QQScLauncher.exe");
}catch(IOException e){
e.printStackTrace();
}
}
else if(tmp.equals("D")){
Enumeration ee=pp.propertyNames();
while(ee.hasMoreElements()){
//获取系统属性的key
String key=(String)ee.nextElement();
String value=System.getProperty(key);
System.out.println(key+"--->"+value);
}
}
else if(tmp.equals("G")){
break;
}
}
}
}
3.4 运行结果
请选择操作 【请用大写字母】:
*************************************
A:记事本
B:重启计算机
C:启动QQ
D:查看系统操作
G:退出
D
java.runtime.name--->Java(TM) SE Runtime Environment
sun.boot.library.path--->E:\Java base\jdk\jre\bin
java.vm.version--->25.291-b10
java.vm.vendor--->Oracle Corporation
java.vendor.url--->http://java.oracle.com/
path.separator--->;
java.vm.name--->Java HotSpot(TM) 64-Bit Server VM