gpt4 book ai didi

java - 如何找出某个字符是字符串中第一次、第二次还是第三次出现?

转载 作者:行者123 更新时间:2023-12-01 18:28:33 24 4
gpt4 key购买 nike

如果我有一个像“telephone”这样的字符串,并且希望输出以 tel*phon* 的形式返回,我该怎么做?

程序将打印出字符串中的每个字母。如果这是第一次出现这封信,那么我会写它。但如果它再次出现,我会打印一个星号。

你好,就是 hel*o

再见就是再见

协调将是co*rdinat***(哎呀,你是对的)

请帮忙谢谢!这不是作业……这是期末考试的练习!谢谢!!

我正在尝试类似...但我只是不知道如何进一步...请帮助

Scanner keyboard = new Scanner(System.in);
String s;
int i, j, count;
System.out.print("Enter string: ");
s = keyboard.nextLine();



for(i=0; i < s.length(); i++){
count = 0;
for(j=i+1; i < s.length(); j++){
if(s.charAt(i) == s.charAt(j)){
count++;
}
if(count < 1)
System.out.print(s.charAt(i));
else
System.out.print("*");
}
}

有人告诉我发布我的代码,所以我现在就发布了。我将如何编辑这个确切的代码以使其工作?请帮忙:(

最佳答案

这里有一个方便的方法。 Setadd() 上有一个 boolean 属性,如果该值已插入到集合中,则返回 false。

方法:创建一个数据结构,以便您可以保证仅将唯一值插入其中。如果将唯一值插入其中,则可以继续构建返回字符串。如果没有,那么您需要生成星号。

引用下面的代码。为了保证对大写和小写字符的公正处理,请在 .toCharArray() 之前调用 toLowerCase()

public static String filterChars(final String word) {
final Set<Character> set = new HashSet<>();

final StringBuilder builder = new StringBuilder();
for(Character c : word.toCharArray()) {
if(set.add(c)) {
builder.append(c);
} else {
builder.append('*');
}
}
return builder.toString();
}

关于java - 如何找出某个字符是字符串中第一次、第二次还是第三次出现?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25149353/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com