第八节 字符串
今日作业:
题目1#
小题1#
键盘录入一个字符串,
要求1:长度为小于等于9
要求2:只能是数字
将内容变成罗马数字
下面是阿拉伯数字跟罗马数字的对比关系:
Ⅰ-1、Ⅱ-2、Ⅲ-3、Ⅳ-4、Ⅴ-5、Ⅵ-6、Ⅶ-7、Ⅷ-8、Ⅸ-9
注意点:
罗马数字里面是没有0的
如果键盘录入的数字包含0,可以变成""(长度为0的字符串)
方法一
import java.util.Scanner;
public class test2 {
public static void main(String[] args) {
//1.键盘录入一个字符串
//书写Scanner的代码
Scanner sc = new Scanner(System.in);
String str;
while (true) {
System.out.println("请输入一个字符串");
str = sc.next();
//2.校验字符串是否满足规则
boolean flag = checkStr(str);
if (flag) {
break;
} else {
System.out.println("当前的字符串不符合规则,请重新输入");
continue;
}
}
//将内容变成罗马数字
//下面是阿拉伯数字跟罗马数字的对比关系:
//Ⅰ-1、Ⅱ-2、Ⅲ-3、Ⅳ-4、Ⅴ-5、Ⅵ-6、Ⅶ-7、Ⅷ-8、Ⅸ-9
//查表法:数字跟数据产生一个对应关系
StringBuilder sb = new StringBuilder();
for (int i = 0; i < str.length(); i++) {
char c = str.charAt(i);
String s = changeLuoMa(c);
sb.append(s);
}
System.out.println(sb);
}
// 利用switch进行匹配
public static String changeLuoMa(char number) {
String str = switch (number){
case '0' -> "";
case '1' -> "Ⅰ";
case '2' -> "Ⅱ";
case '3' -> "Ⅲ";
case '4' -> "Ⅳ";
case '5' -> "Ⅴ";
case '6' -> "Ⅵ";
case '7' -> "Ⅶ";
case '8' -> "Ⅷ";
case '9' -> "Ⅸ";
default -> str = "";
};
return str;
}
public static boolean checkStr(String str) {//123456
//要求1:长度为小于等于9
if (str.length() > 9) {
return false;
}
//要求2:只能是数字
for (int i = 0; i < str.length(); i++) {
char c = str.charAt(i);//0~9
if (c < '0' || c > '9') {
return false;
}
}
//只有当字符串里面所有的字符全都判断完毕了,我才能认为当前的字符串是符合规则
return true;
}
}
方法二
import java.util.Scanner;
public class test3 {
public static void main(String[] args) {
//1.键盘录入一个字符串
//书写Scanner的代码
Scanner sc = new Scanner(System.in);
String str;
while (true) {
System.out.println("请输入一个字符串");
str = sc.next();
//2.校验字符串是否满足规则
boolean flag = checkStr(str);
if (flag) {
break;
} else {
System.out.println("当前的字符串不符合规则,请重新输入");
continue;
}
}
//将内容变成罗马数字
//下面是阿拉伯数字跟罗马数字的对比关系:
//Ⅰ-1、Ⅱ-2、Ⅲ-3、Ⅳ-4、Ⅴ-5、Ⅵ-6、Ⅶ-7、Ⅷ-8、Ⅸ-9
//查表法:数字跟数据产生一个对应关系
StringBuilder sb = new StringBuilder();
for (int i = 0; i < str.length(); i++) {
char c = str.charAt(i);
int number = c - 48; // 1 2 3 4 5
String s = changeLuoMa(number);
sb.append(s);
}
System.out.println(sb);
}
public static String changeLuoMa(int number) {
//定义一个数组,让索引跟罗马数字产生一个对应关系
String[] arr = {"", "Ⅰ", "Ⅱ", "Ⅲ", "Ⅳ", "Ⅴ", "Ⅵ", "Ⅶ", "Ⅷ", "Ⅸ"};
return arr[number];
}
public static boolean checkStr(String str) {//123456
//要求1:长度为小于等于9
if (str.length() > 9) {
return false;
}
//要求2:只能是数字
for (int i = 0; i < str.length(); i++) {
char c = str.charAt(i);//0~9
if (c < '0' || c > '9') {
return false;
}
}
//只有当字符串里面所有的字符全都判断完毕了,我才能认为当前的字符串是符合规则
return true;
}
}
小题2#
给定两个字符串, A和B。
A的旋转操作就是将A 最左边的字符移动到最右边。
例如, 若A = 'abcde',在移动一次之后结果就是'bcdea'
如果在若干次调整操作之后,A能变成B,那么返回True。
如果不能匹配成功,则返回false
方法一
public class test4 {
public static void main(String[] args) {
// 1.定义两个字符串
String strA = "abcde";
String strB = "ABC";
// 2.调用方法进行比较
boolean result = check(strA, strB);
// 3.输出
System.out.println(result);
}
public static boolean check(String strA, String strB) {
for (int i = 0; i < strA.length(); i++) {
strA = rotate(strA);
if(strA.equals(strB)) {
return true;
}
}
// 所有的情况都比较完毕了,还不一样那么直接返回false
return false;
}
// 作用:选择字符串,把左侧的字符移动到右侧去
// 形参:旋转前的字符串
// 返回值:旋转后的字符串
public static String rotate(String str){
// 套路:
// 如果我们看到要修改字符串的内容
// 可以有两个办法:
// 1.用subString进行截取,把左边的字符截取出来拼接到哦右侧去
// 2.可以把字符串先变成一个字符数组,然后调整字符数组里面数据,最后再把字符数组变成字符串
// 截取思路
// 获取最左侧那个字符
char first = str.charAt(0);
// 获取剩余的字符
String end = str.substring(1);
return end + first;
}
}
方法二
public class test5 {
public static void main(String[] args) {
// 1.定义两个字符串
String strA = "abcde";
String strB = "bcdea";
// 2.调用方法进行比较
boolean result = check(strA, strB);
// 3.输出
System.out.println(result);
}
public static boolean check(String strA, String strB) {
for (int i = 0; i < strA.length(); i++) {
strA = rotate(strA);
if (strA.equals(strB)) {
return true;
}
}
// 所有的情况都比较完毕了,还不一样那么直接返回false
return false;
}
// 作用:选择字符串,把左侧的字符移动到右侧去
// 形参:旋转前的字符串
// 返回值:旋转后的字符串
public static String rotate(String str) {
// 套路:
// 如果我们看到要修改字符串的内容
// 可以有两个办法:
// 1.用subString进行截取,把左边的字符截取出来拼接到哦右侧去
// 2.可以把字符串先变成一个字符数组,然后调整字符数组里面数据,最后再把字符数组变成字符串
// 可以把字符串先变成一个字符数组,然后调整字符数组里面数据,最后再把字符数组变成字符串.
// "ABC" ['A', 'B', 'C'] ['B', 'C', 'A'] new String(字符数组);
char[] arr = str.toCharArray();
// 拿到0索引上的字符
char first = arr[0];
// 把剩余的字符依次往前挪一个位置
for (int i = 1; i < arr.length; i++) {
arr[i - 1] = arr[i];
}
// 把原来0索引上的字符放到最后一个索引
arr[arr.length - 1] = first;
// 利用字符数组创建一个字符串对象
String result = new String(arr);
return result;
}
}
小题3#
键盘输入任意字符串,打乱里面的内容
import java.util.Random;
public class test6 {
public static void main(String[] args) {
// 键盘输入任意字符串,打乱里面的内容
// 1.键盘输入任意字符串
String str = "abcdefg";
// 2.打乱里面的内容
// 修改字符串里面的内容:
// 1.subString
// 2.变成字符数组
char[] arr = str.toCharArray(); // ['a', 'b', 'c', 'd', 'e', 'f', 'g']
// 3.打乱数组里面的内容
// 从0索引开始,跟一个随机索引进行位置的交换
// 当数组里面的每一个元素都跟一个随机索引进行交换完毕后,那么内容就打乱了
for (int i = 0; i < arr.length; i++) {
Random r = new Random();
int rnumber = r.nextInt(arr.length);
char temp = arr[i];
arr[i] = arr[rnumber];
arr[rnumber] = temp;
}
// 4.把字符数组再变回字符串
String result = new String(arr);
System.out.println(result);
}
}
小题4#
生成验证码
内容:可以是小写字母,也可以是大写字母,还可以是数字
规则:
长度为5
内容中是四位字母,1位数字
其中数字只有1位,但是可以出现再任意的位置
import java.util.Random;
public class test7 {
public static void main(String[] args) {
// 1.可以把所有的大写字母,小写字母都放到一个数组当中
char[] chs = new char[52];
for (int i = 0; i < chs.length; i++) {
//ASCII码表
if(i <= 25){
//添加小写字母
chs[i] = (char)(97 + i);
}else{//27
//添加大写字母
// A --- 65
chs[i] = (char)(65 + i - 26);
}
}
// a-z A-Z
//定义一个字符串类型的变量,用来记录最终的结果
String code = "";
// 2.从数组中随机获取4次
//随机抽取数组中的索引
Random r = new Random();
for (int i = 0; i < 4; i++) {
int randomIndex = r.nextInt(chs.length);
//利用随机索引,获取对应的元素
code = code + chs[randomIndex];
}
// 3.生成一个0-9之间的随机数拼接到最后
int number = r.nextInt(10);
code = code + number;
// ACFG7
// 思考:我们把7放到前面,修改了字符串的内容
// 把生成的验证码先变成一个字符数组
// 再让最后一个元素跟前面的随机位置地元素进行交换
// 交换完毕之后再变成字符串就可以了
char[] arr = code.toCharArray();
//将数组里面的内容打乱
for (int i = 0; i < arr.length; i++) {
int index = r.nextInt(arr.length);
char temp = arr[i];
arr[i] = arr[index];
arr[index] = temp;
}
//将字符数组再变回字符串
String result = new String(arr);
//输出打印
System.out.println(result);
}
}
小题5#
给定两个以字符串形式表示地非负整数num1和num2,返回num1和num2的乘积,它们的乘积也表示为字符串的形式。
public class test8 {
public static void main(String[] args) {
/*给定两个以字符串形式表示地非负整数num1和num2,返回num1和num2的乘积,它们的乘积也表示为字符串的形式。
* 注意:需要用已有的知识完成*/
// 不需要考虑乘积过大之后的结果
// 就认为乘积一定是小于int的最大值了
// 注:本题给的例子就是大于int的最大值的
String num1 = "123456789";
String num2 = "123456";
// 1.把num1和num2变成对应的整数才可以
// "123456789"
// 先遍历字符串依次得到每一个字符 '1' '2' '3' '4' '5' '6' '7' '8' '9'
// 再把字符变成对应的数字即可 1 2 3 4 5 6 7 8 9
// 把每一个数字组合到一起 123456789
int m = num1.length();
int n = num2.length();
// 定义数字
int number1 = 0;
int number2 = 0;
// 2.利用整数进行相乘
// 从左往右遍历num1的每一位数字
for (int i = 0; i < m; i++) {
int digit1 = num1.charAt(i) - '0';
number1 = number1 * 10 + digit1;
}
// 从左往右遍历num2的每一位数字
for (int j = 0; j < n; j++) {
int digit2 = num2.charAt(j) - '0';
number2 = number2 * 10 + digit2;
}
int sum = number1 * number2;
// 3.可以把整数变成字符串
// 构造结果字符串
// + ""
String result = "";
result = result + sum;
System.out.println(result);
}
}
小题6(暂未做出,仅有思路呜呜呜)#
public class test9 {
public static void main(String[] args) {
/* 给你一个字符串 s,由若干单词组成,单词前后用一些空格字符隔开。
返回字符串中最后一个单词的长度。
单词是指仅由字母组成、不包含任何空格字符的最大子字符串。
示例 1:输入:s = "Hello World“ 输出:5
解释:最后一个单词是“World”,长度为5。
示例 2:输入:s = " fly me to the moon" 输出:4
解释:最后一个单词是“moon”,长度为4。
示例 3:输入:s = "luffy is still joyboy" 输出:6
解释:最后一个单词是长度为6的“joyboy”。*/
//倒着遍历
//直到遇到空格为止
//那么遍历的次数就是单词的长度
}
}
题目2#
键盘输入任意字符串,打乱里面的内容
训练目标#
随机数类Random相关API、字符串相关API
训练提示#
1、字符串是不可变的
2、如果要变化需要变成字符数组
3、调整完毕之后再变回字符串
参考答案#
public class Test {
public static void main(String[] args) {
//键盘录入字符串
Scanner sc = new Scanner(System.in);
System.out.println("请输入一个字符串");
String str = sc.next();
//把字符串变成字符数组
char[] arr = str.toCharArray();
//将数组里面的内容打乱
//打乱的核心要素:
//遍历数组得到每一个元素与每一个随机索引处的数据进行交换
Random r = new Random();
for (int i = 0; i < arr.length; i++) {
int index = r.nextInt(arr.length);
char temp = arr[i];
arr[i] = arr[index];
arr[index] = temp;
}
//将字符数组再变回字符串
String newStr = new String(arr);
//输出打印
System.out.println(newStr);
}
}
题目3#
训练目标:#
生成验证码
内容:可以是小写字母,也可以是大写字母,还可以是数字
规则:
长度为5
内容中是四位字母,1位数字。
其中数字只有1位,但是可以出现在任意的位置。
参考答案#
public class Test {
public static void main(String[] args) {
//1.大写字母和小写字母都放到数组当中
char[] chs = new char[52];
for (int i = 0; i < chs.length; i++) {
//ASCII码表
if(i <= 25){
//添加小写字母
chs[i] = (char)(97 + i);
}else{//27
//添加大写字母
// A --- 65
chs[i] = (char)(65 + i - 26);
}
}
//定义一个字符串类型的变量,用来记录最终的结果
String code = "";
//2.随机抽取4次
//随机抽取数组中的索引
Random r = new Random();
for (int i = 0; i < 4; i++) {
int randomIndex = r.nextInt(chs.length);
//利用随机索引,获取对应的元素
//System.out.println(chs[randomIndex]);
code = code + chs[randomIndex];
}
//System.out.println(result);
//3.随机抽取一个数字0~9
int number = r.nextInt(10);
//生成最终的结果
code = code + number;
//4.变成字符数组打乱数据
char[] arr = code.toCharArray();
//将数组里面的内容打乱
for (int i = 0; i < arr.length; i++) {
int index = r.nextInt(arr.length);
char temp = arr[i];
arr[i] = arr[index];
arr[index] = temp;
}
//将字符数组再变回字符串
String result = new String(arr);
//输出打印
System.out.println(result);
}
}
题目4#
请编写程序,由键盘录入一个字符串,统计字符串中英文字母和数字分别有多少个。比如:Hello12345World中字母:10个,数字:5个。
训练目标#
字符串遍历
训练提示#
1、键盘录入一个字符串,用 Scanner 实现
2、要统计两种类型的字符个数,需定义两个统计变量,初始值都为0
3、遍历字符串,得到每一个字符
4、判断该字符属于哪种类型,然后对应类型的统计变量+1,判断字母时需要考虑大小写,条件比较复杂,怎样做才能使判断更简单呢?
训练步骤#
1、创建键盘录入Scanner对象,使用nextLine方法接收输入的字符串。
2、为方便后续判断,使用String的toLowerCase方法,将字符串中的字符都转为小写。
3、需定义两个统计变量,初始值都为0
4、遍历字符串,得到每一个字符
5、判断该字符属于哪种类型,然后对应类型的统计变量+1,次数判断英文字母时只需判断小写即可。
参考答案#
import java.util.Scanner;
public class Test {
public static void main(String[] args) {
//键盘录入一个字符串,用 Scanner 实现
Scanner sc = new Scanner(System.in);
System.out.println("请输入一个字符串:");
String line = sc.nextLine();
// 为方便统计,将字符串中的字母都转为小写
line = line.toLowerCase();
//要统计两种类型的字符个数,需定义两个统计变量,初始值都为0
int letterCount = 0;
int numberCount = 0;
// 遍历字符串,得到每一个字符
for(int i=0; i<line.length(); i++) {
char ch = line.charAt(i);
// 判断该字符属于哪种类型,然后对应类型的统计变量+1
if (ch >= 'a' && ch <= 'z') {
letterCount++;
} else if (ch >= '0' && ch <= '9') {
numberCount++;
}
}
//输出两种类型的字符个数
System.out.println("英文字母:" + letterCount + "个");
System.out.println("数字:" + numberCount + "个");
}
}
题目5#
请定义一个方法用于判断一个字符串是否是对称的字符串,并在主方法中测试方法。例如:"abcba"、"上海自来水来自海上"均为对称字符串。
训练目标#
字符串的反转功能,判断是否相等功能
训练提示#
1、判断是否对称,方法的返回值是什么类型?参数列表是什么?
2、怎样判断对称呢?如果可以将字符串反转,反转后发现跟原来的字符串完全一样,不就可以判断出来了吗,那么哪个类有字符串的反转功能呢?
训练步骤#
1、定义方法,返回值类型为boolean,参数列表为String类型的一个参数。
2、将字符串转换为StringBuilder类型,调用StringBuilder的reverse()方法将字符串反转。
3、将反转后的字符串再转回String类型,并与原字符串比较,如果相等,返回true,否则返回false
4、在主方法中,定义一个字符串,调用方法测试结果。
参考答案#
public class Test {
public static void main(String[] args) {
String str = "上海自来水来自海上";
System.out.println(isSym(str));
}
public static boolean isSym(String str) {
// 为了程序的健壮,如果传递的是空值,返回false
if (str == null) {
return false;
}
// 转换为StringBuilder
StringBuilder sb = new StringBuilder(str);
// 反转,再转成String
String reStr = sb.reverse().toString();
// 比较与原字符串是否相等
// 相等返回true,不相等返回false,正好与equals的返回值一致,直接返回即可。
return reStr.equals(str);
}
}
题目6#
我国的居民身份证号码,由由十七位数字本体码和一位数字校验码组成。请定义方法判断用户输入的身份证号码是否合法,并在主方法中调用方法测试结果。规则为:号码为18位,不能以数字0开头,前17位只可以是数字,最后一位可以是数字或者大写字母X。
训练目标#
字符串的遍历、判断
训练提示#
1、要判断字符串是否符合规则,方法的返回值类型是什么?参数列表是什么?
2、使用String的API,对每种不符合条件的情况作出判断,一旦发现不符合条件就可以结束方法的执行,返回结果了。
3、在主方法中创建键盘录入,调用方法,输入各种数据测试结果。
训练步骤#
1、定义方法,返回值类型为boolean表示是否合法,参数列表为String类型的id,表示要判断的数据。
2、对每种不符合条件的情况作出判断
2.1、如果字符串长度不是18,返回false。
2.2、如果字符串以数字"0"开头,返回false。
2.3、遍历字符串,获取每一位字符,判断前17位,如果不是数字,返回false,判断最后一位如果不是数字或者X,返回false
2.4、所以的不符合条件都筛选完成,返回true
3、在主方法中创建键盘录入Scanner对象,调用nextLine()方法,获取用户输入,调用方法,传递参数,查看结果。要多运行几次,判断各种不符合条件的数据。
参考答案#
import java.util.Scanner;
public class Test {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.println("请输入身份证号:");
String id = sc.nextLine();
System.out.println(check(id));
}
// 返回值boolean类型,表示是否符合规则。参数列表:需要判断的字符串
public static boolean check(String id) {
// 如果传递了空参数,返回false
if (id == null) {
return false;
}
// 如果是数字0开头,返回false
if (id.startsWith("0")) {
return false;
}
// 如果不是18位,返回false
if (id.length() != 18) {
return false;
}
// 遍历判断每一位
for (int i = 0; i < id.length(); i++) {
char ch = id.charAt(i);
// 前17位都是数字,最后一位可以是数字或者大写字母X
if (i == id.length() - 1) { // 最后一位
if (ch < '0' || ch > '9' && ch != 'X') { // 不是数字或者X
return false;
}
} else { // 其他位
if (ch < '0' || ch > '9') { // 不是数字
return false;
}
}
}
// 所有的规则都符合,返回true
return true;
}
}
题目7#
定义一个方法,把 int 数组中的数据按照指定的格式拼接成一个字符串返回,调用该方法,并在控制台输出结果。
要求:
1、如果传递的参数为空,返回null
2、如果传递的数组元素个数为0,返回[]
3、如果数组为int[] arr = {1,2,3}; ,执行方法后的输出结果为:[1, 2, 3]
训练目标#
字符串的拼接
训练提示#
1、定义方法的返回值是什么?参数列表是什么?
2、如果不做判断就对数组进行遍历,那么如果数组对象为空,会报出异常,怎样避免空指针异常呢?
3、拼接字符串必然涉及到频繁改变,该采用可变的字符序列StringBuilder比较好
4、遍历数组,按照题目格式拼接数组中的元素。
5、将字符串返回
6、在主方法中定义数组,并调用方法,打印结果
训练步骤#
1、定义方法返回值类型:String,参数:int[] arr
2、判断对象如果为null,直接返回null
3、创建StringBuilder对象
4、遍历数组,按照要求进行拼接数组元素,如果是不是最后一个元素,还要拼接逗号和空格
5、将StringBuilder转为String返回
6、在主方法中定义数组,并调用方法,打印结果
参考答案1#
public class Test {
public static void main(String[] args) {
// 定义一个 int 类型的数组,用静态初始化完成数组元素的初始化
int[] arr = {1, 2, 3};
// 调用方法,输出结果
System.out.println(arrayToString(arr));
}
/*定义一个方法,用于把 int 数组中的数据按照指定格式拼接成一个字符串返回
返回值类型:String
参数:int[] arr
*/
public static String arrayToString(int[] arr) {
// 健壮性判断
if (arr == null) {
return null;
}
//在方法中用 StringBuilder 按照要求进行拼接,并把结果转成 String 返回
StringBuilder sb = new StringBuilder();
sb.append("[");
for (int i = 0; i < arr.length; i++) {
// 拼接元素
sb.append(arr[i]);
// 如果不是最后一个元素,再拼接逗号和空格
if (i != arr.length - 1) {
sb.append(", ");
}
}
sb.append("]");
return sb.toString();
}
}
参考答案2:#
public class Test {
public static void main(String[] args) {
// 定义一个 int 类型的数组,用静态初始化完成数组元素的初始化
int[] arr = {1, 2, 3};
// 调用方法,输出结果
System.out.println(arrayToString(arr));
}
public static String arrayToString(int[] arr) {
// 健壮性判断
if (arr == null) {
return null;
}
//在方法中用 StringBuilder 按照要求进行拼接,并把结果转成 String 返回
StringJoiner sj = new StringJoiner(", ","[","]");
for (int i = 0; i < arr.length; i++) {
sj.add(arr[i] + "");
}
return sj.toString();
}
}
题目8(扩展)#
在String类的API中,有如下两个方法:
// 查找参数字符串str在调用方法的字符串中第一次出现的索引,如果不存在,返回-1
public int indexOf(String str)
// 截取字符串,从索引beginIndex(包含)开始到字符串的结尾
public String substring(int beginIndex)
请仔细阅读API中这两个方法的解释,完成如下需求。
现有如下文本:"Java语言是面向对象的,Java语言是健壮的,Java语言是安全的,Java是高性能的,Java语言是跨平台的"。请编写程序,统计该文本中"Java"一词出现的次数。
训练目标#
String类API的灵活使用
训练提示#
1、要找的子串是否存在,如果存在获取其出现的位置。这个可以使用indexOf完成。
2、如果找到了,那么就记录出现的位置并在剩余的字符串中继续查找该子串,而剩余字符串的起始位是出现位置再加上子串的长度。
3、以此类推,通过循环完成查找,如果找不到就是-1,每次找到用计数器记录次数。
训练步骤#
1、定义方法,返回值int表示次数,参数列表两个字符串,第一个表示在哪个字符串中查找,第二个表示要查找的目标子串
2、定义统计变量表示次数。
3、定义索引变量,表示每次找到子串出现的索引。
4、定义循环,判断条件为在字符串中找到了目标子串,使用indexOf实现。
5、如果找到的索引不是-1,在循环中,统计变量累加。
6、把查找过的部分剪切掉,从找到的索引+子串长度的位置开始截取,使用substring实现。
7、将统计变量返回
8、在主方法中,定义字符串表示题目中的文本,定义字符串表示要查找的子串,调用方法,获取结果。
参考答案1#
public class Test {
public static void main(String[] args) {
String str = "Java语言是面向对象的,Java语言是健壮的,Java语言是安全的,Java是高性能的,Java语言是跨平台的";
String tar = "Java";
// 调用方法并输出
System.out.println(search(str, tar));
}
// 返回值int表示次数,参数列表str表示在哪个字符串中查找,tar表示要查找的目标子串
public static int search(String str, String tar) {
// 定义统计变量表示次数
int count = 0;
// 定义索引变量,表示每次找到子串出现的索引
int index = -1;
// 定义循环,判断条件为在字符串中找到了目标子串
while ((index = str.indexOf(tar)) != -1) { // 将找到的索引赋值给变量并判断
// 次数累加
count++;
// 把查找过的部分剪切掉,从找到的索引+子串长度的位置开始截取。
str = str.substring(index + tar.length());
}
return count;
}
}
参考答案2#
public class Test {
public static void main(String[] args) {
String str = "Java语言是面向对象的,Java语言是健壮的,Java语言是安全的,Java是高性能的,Java语言是跨平台的";
String tar = "Java";
// 调用方法并输出
System.out.println(search(str, tar));
}
// 替换之后求长度差
public static int search(String str, String tar) {
String newStr = str.replace(tar, "");
int count = (str.length() - newStr.length()) / tar.length();
return count;
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
· 零经验选手,Compose 一天开发一款小游戏!