为多个Array项打印单个计数值



我有一个非常快速的问题,我猜只是盯着我看,但我看不到它。我必须计算某个名字在数组中出现的次数。我使用循环,因为我不允许使用类,hashmap等。所以我有93个名字,例如Jake出现了5次,我希望输出是:

       Jack - 5
相反,我的程序显示
       Jack - 5
       Jack - 5
       Jack - 5
       Jack - 5
       Jack - 5

我只想打印一次,这是我的循环:

for (int counter = 0; counter < name.length; counter++)
    {
        String n = (name[counter]);
        int count = 0;
        for (int i = 0; i < name.length; i++){
            if (name[i].equals(n))
                count++;
        }
        System.out.println(n + " - " + count);
    }

理想输出应为:

                  Jack - 5

我需要打印星号作为输出,所以我想让它说

                 Jack (5) ***** 

每个星号代表一个事件,我知道如何打印它们,我把它放在我的代码中,但它显示

                ***** Jack(5) 

我想知道我该如何解决这个问题,有什么想法吗?

您循环遍历列表中的每个名称并每次检查它。因此,您将检查名称Jack 5次,因此您将得到5个输出。

由于某些原因你不允许使用hashmap,这应该解决它:

String name[] = new String[]{"jack", "jack", "jack", "james", "jack", "jack", "james"};
ArrayList<String> checkedNames = new ArrayList<String>();
for (int counter = 0; counter < name.length; counter++)
{
    String n = (name[counter]);
    if(!checkedNames.contains(n))
    {
        int count = 0;
        for (int i = 0; i < name.length; i++){
            if (name[i].equals(n))
                count++;
        }
        checkedNames.add(n);
        System.out.println(n + " - " + count);
    }
}

编辑:因为你不能使用数组列表,但可以对数组进行排序:

    String name[] = new String[]{"jack", "jack", "jack", "jack", "jack", "james"};
    String lastName = "";
    Arrays.sort(name);
    for (int counter = 0; counter < name.length; counter++)
    {
        String n = (name[counter]);

        if(!lastName.equals(n))
        {
            int count = 0;
            for (int i = 0; i < name.length; i++){
                if (name[i].equals(n))
                    count++;
            }
            System.out.println(n + " - " + count);
        }
        lastName = n;
    }

第二个编辑:

首先,Arrays是Java内置的类,就像String一样:

http://docs.oracle.com/javase/6/docs/api/java/util/Arrays.htmlhttp://docs.oracle.com/javase/1.5.0/docs/api/java/lang/String.html

其次,如果你想打印星号,那么把System.out.println行改成这样:
System.out.println(n + " (" + count + ")" + new String(new char[count]).replace("", "*"));

请检查下一个代码:

for (int counter = 0; counter < name.length; counter++)
    {
        String n = (name[counter]);
        int count = 0;
        boolean flag = true;
        for (int i = 0; i < counter; i++){
            if (name[i].equals(n)) {
               flag = false;
            }
        }
        if (flag) {
           for (int i = 0; i < name.length; i++){
               if (name[i].equals(n))
                   count++;
           }
           System.out.println(n + " - " + count);
        }
    }

在这里,您检查如果选定的名称尚未在数组中(从0到计数器),那么您将计算它在数组和显示信息中保留的次数。

您是否会尝试使用不同的数组(例如encouteredNames)来存储您已经计算过的出现次数的名称?然后,只有当您确定要搜索的名称以前没有被搜索过(或者它仍然没有存储在encounteredNames数组中)时,才执行'counting'循环。

我相信有比这更好的实现,但同时:

String[] names = {"Jack", "James", "Charles", "Jack", "Jack", "James"};
String[] encounteredNames = new String[names.length];
int encounteredNamesCount = 0;
for (int counter = 0; counter < names.length; counter++) {
  String name = (names[counter]);
  boolean nameAlreadyEncountered = false;
  for (int i = 0; i < encounteredNames.length && encounteredNames[i] != null; i++) {
    if (encounteredNames[i] == name) {
      nameAlreadyEncountered = true;
      break;
    }
  }
  if (!nameAlreadyEncountered) {
    encounteredNames[encounteredNamesCount++] = name;
    int count = 0;
    for (int i = 0; i < names.length; i++){
      if (names[i].equals(name)) {
        count++;
      }
    }
    System.out.println(name + " - " + count);
  }
}

最新更新