1

所以我有这个任务,我必须输入两个字符串,然后我必须找到常见的字母,然后把它们写出来,但只写一次..例如,如果 string1 是“拟声词”,而 string2 是“对话”我应该回来:o,n,a,t,e,i... 我唯一的问题是最后一部分(“我不知道如何只写一次字母)

这是我的代码

import java.util.Scanner;
import java.util.Arrays;

public class Zadatak4 {

    /**
     * @param args
     */
    public static void main(String[] args) {

        Scanner scan = new Scanner(System.in);
        char niz[] = new char[100];
        char niz2[] = new char[100];

        System.out.print("Add the first string: ");
        niz = scan.nextLine().toCharArray();

        System.out.print("Add the second string: ");
        niz2 = scan.nextLine().toCharArray();

        for (int i = 0; i < niz.length; i++) {

            for (int j = 0; j < niz2.length; j++) {

                if (niz[i] == niz2[j]) {
                    System.out.println(niz[i] + " ");

                    // What now!?!?!?
                }

            }
        }

    }

}
4

7 回答 7

2

使用一组:

LinkedHashSet<string> printNum = new LinkedHashSet<string>();
if(niz[i] == niz2[j])
{
      printNum.add( niz[i] );
}

// outside of loop
for( string s : printNum )
{
      System.out.println(s);
}
于 2013-06-21T17:53:33.990 回答
1

你需要的是两个集合的交集,所以你可以使用的是Set.retainAll().

于 2013-06-21T18:15:13.497 回答
1

一个班轮:

HashSet<Character> common =
    new HashSet<Character>(Arrays.asList(niz1)).retainAll(
        new HashSet<Character>(Arrays.asList(niz2)));
于 2013-06-21T18:25:09.120 回答
1

在你的 for 循环的最里面,你会想要将它们添加到一个集合中

mutuals.add(niz[i])

然后在开头的循环之外添加这个来声明它

Set<char> mutuals = new HashSet<char>()

确保在循环之外执行此操作

然后,打印出相互之间的所有内容

于 2013-06-21T17:55:55.530 回答
1

几乎每个人都建议Set,这是很难做到的......

public static void main(String[] args) {

    String printed = "";

    Scanner scan = new Scanner(System.in);
    char niz[] = new char[100];
    char niz2[] = new char[100];


    System.out.print("Add the first string: ");
    niz = scan.nextLine().toCharArray();

    System.out.print("Add the second string: ");
    niz2 = scan.nextLine().toCharArray();


    for(int i = 0; i < niz.length; i++)
    {
        for(int j = 0; j < niz2.length; j++)
        {
                if(niz[i] == niz2[j])
                {                        
                    if(printed.indexOf(niz[i]) == -1) {
                           System.out.println(niz[i]+" ");
                    }

                    printed += niz[i];
                }
        }
    }
于 2013-06-21T18:09:11.160 回答
1

您可以通过使用两个HashSets.

每个单词都有一个哈希集。当您在 word1 中遇到一个字母时,您输入 set1。当您在 word2 中遇到字母时,您输入 set2。

最后,您只保留两组中的字母。

import java.util.HashSet;
public class Zadatak4 {

    /**
     * @param args
     */
    public static void main(String[] args) {


        Scanner scan = new Scanner(System.in);
        char niz[] = new char[100];
        char niz2[] = new char[100];

        System.out.print("Add the first string: ");
        niz = scan.nextLine().toCharArray();

        System.out.print("Add the second string: ");
        niz2 = scan.nextLine().toCharArray();

        HashSet<Integer> set1 = new <String>HashSet();
        HashSet<Integer> set2 = new <String>HashSet();


        for(int i = 0; i < niz.length; i++)
        {
            if(!set1.contains(niz[i]));
            set1.add((int) niz[i]);         
        }

        for(int i = 0; i < niz2.length; i++)
        {
            if(!set2.contains(niz2[i]));
            set2.add((int) niz2[i]);            
        }


        Iterator<Integer> it = set1.iterator();
        int currentChar;
        while(it.hasNext())
        {
            currentChar = it.next();
            if(set2.contains(currentChar))
            System.out.println((char)currentChar);
        }
    }

}
于 2013-06-21T17:53:29.987 回答
0

将字符存储在 Set in

 Set<Character> cs=new HashSet<>();

 if(niz[i] == niz2[j])
 {
     cs.add(niz[i]); 
     //System.out.println(niz[i]+" ");

     //What now!?!?!?
 }
于 2013-06-21T17:54:54.493 回答