0

以下代码将重复的名称分隔为 1 列,将与名称关联的数字总和分隔为第二列。

像 :

   Nokia 21

   Blackberry 3

   Nimbus 30

从程序中给出的数组中。


我想知道包含这些条目的数组的最终长度。在这种情况下 3. 我该如何计算?

package keylogger;
import java.util.ArrayList;
import java.util.List;

public class ArrayTester {

private static int finalLength = 0;
private static String Name[][];
private static String data[][] = { 
                               {"Nokia" , "7"},
                               {"Blackberry" ,"1"},
                               {"Nimbus","10"},
                               {"Nokia" , "7"},
                               {"Blackberry" , "1"},
                               {"Nimbus","10"},
                               {"Nokia" , "7"},
                               {"Blackberry" , "1"},
                               {"Nimbus","10"}

                          };  

public void calculator() {

    Name = new String[data.length][2];
    List<String> marked = new ArrayList<String>();
    try {
        for(int i=0;i<data.length;i++) {
            Name[i][0] = data[i][0];
            Name[i][1] = data[i][1];
            String name = data[i][0];
            if(marked.contains(name)) {

                continue;
            }
            marked.add(name);
            int k = i + 1;
            int v = k;
            for (int j = 0; j < data.length - v; j++) {
                String s = data[k][0];
                if(Name[i][0].equalsIgnoreCase(s)) {
                    Name[i][0] = s;
                    Integer z = Integer.parseInt(Name[i][1]) + Integer.parseInt(data[k][1]);
                    Name[i][1] = z.toString();
                }
                k++;
            }

        }
    }catch(Exception exc) {
        exc.printStackTrace();
    }
}

public static void main(String args[]) {
    ArrayTester o = new ArrayTester();
    o.calculator();
    for(String s[] : Name) {
        for(String x : s) {
            System.out.println(x);
        }
    }
}

}

4

3 回答 3

2

您无法先验地知道它,只有在您完成拆分字符串并进行数学运算时,才会知道大小。

在您的示例中,最终marked.size()将具有您正在寻找的大小,但我建议您直接使用 HashMap 这样您就不会关心在线性时间内搜索现有元素,然后将其转换为数组。

就像是:

String[][] names = new String[map.size()];
Set<String> keys = map.keys();
int c = 0;

for (String k : keys)
{
  names[c] = new String[2];
  names[c][0] = k;
  names[c++][1] = map.get(k).toString();
}
于 2012-05-25T12:55:58.177 回答
2

据我了解,您想知道数组中不同名称的数量而不调用calculator(),对吗?我真的不知道这是否有意义,因为您仍然必须检查每个条目并将其与一组进行比较。但是你可以用 Set 来做到这一点:

private int getNumberOfEntries(String[][] data) {
  Set<String> names = new HashSet<String>();
  for (int i=0; i<data.length; i++) {
    names.add(data[i][1]);
  }
  return names.size();
}

现在你可以打电话int n = getNumberOfEntries(data);...

编辑:当然,在同一步骤中进行求和更有意义,请参阅 Bohemians 解决方案。

于 2012-05-25T13:05:04.537 回答
2

像往常一样,“问题”是糟糕的编码。正确编写的整个程序可以减少到仅 3 行代码(如果包括定义数组和打印输出,则为 5 行):

public static void main(String[] args) {
    String data[][] = {{"Nokia", "7"}, {"Blackberry", "1"}, {"Nimbus", "10"},
        {"Nokia", "7"}, {"Blackberry", "1"}, {"Nimbus", "10"}, {"Nokia", "7"},
        {"Blackberry", "1"}, {"Nimbus", "10"}, {"Zebra", "78"}};

    HashMap<String, Integer> totals = new HashMap<String, Integer>();
    for (String[] datum : data)
        totals.put(datum[0], new Integer(datum[1]) + (totals.containsKey(datum[0]) ? totals.get(datum[0]) : 0));
    System.out.println("There are " + totals.size() + " brands: " + totals);
}

输出:

There are 4 brands: {Nimbus=30, Zebra=78, Nokia=21, Blackberry=3}
于 2012-05-25T13:10:52.757 回答