题目描述
链接:https://www.nowcoder.com/questionTerminal/f0db4c36573d459cae44ac90b90c6212
输入两个字符串,从第一字符串中删除第二个字符串中所有的字符。例如,输入”They are students.”和”aeiou”,则删除之后的第一个字符串变成”Thy r stdnts.”
输入描述:
每个测试输入包含2个字符串
输出描述:
输出删除后的字符串
示例1
输入
They are students.
aeiou
输出
Thy r stdnts.
思路一
比较字符,在字符拼接
代码实现
import java.util.Scanner;
/**
* @ Created with IntelliJ IDEA.
* @ClassName Test2
* @Description
* @Author by
* @Date 2020/6/26 20:08
*/
public class Test2 {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
while(scanner.hasNext()) {
String str1 = scanner.nextLine();
String str2 = scanner.nextLine();
int n1 = str1.length();
int n2 = str2.length();
System.out.println(delect(str1, str2, n1, n2));
}
}
private static String delect(String str1, String str2, int len1, int len2) {
String ans = "";
for (int i = 0; i < len1 ; i++) {
int j = 0;
boolean tmp = true;
while (j < len2 ) {
if(str1.charAt(i) == str2.charAt(j)) {
tmp = false;
break;
}
j++;
}
if(tmp == true) {
ans = ans + str1.charAt(i);
}
}
return ans;
}
}
思路二
就是两层循环遍历,下面将“They are students.”称为字符串1,将“aeiou”称为字符串2。每遍历到字符串2中的一个字符,就在字符串1中找到相同的字符,找到之后删除它,并将字符串1后面的字符整体向前移动1位。
代码实现
import java.util.Scanner;
public class Main{
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
while(sc.hasNext()){
char[] ch = sc.nextLine().toCharArray();
String str = sc.nextLine();
for(int i=0;i<ch.length;i++){
if(!str.contains(String.valueOf(ch[i]))){
System.out.print(ch[i]);
}
}
}
}
}
注释:
toCharArray() 方法 把这个字符串转换成一个新的字符数组.
contains()方法 string类型数据判断时,判断是否包含某个字符串。
String.valueOf(char c) : 将 char 变量 c 转换成字符串
String.valueOf(char[] data) : 将 char 数组 data 转换成字符串
代码3
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
while (sc.hasNext()) {
String s1 = sc.nextLine();
String s2 = sc.nextLine();
String pattern = "[" + s2 + "]";
String result = s1.replaceAll(pattern, "");
System.out.println(result);
}
}
}
replaceAll把源字符串中的某一字符或字符串全部换成指定的字符或字符串