需要知道有没有一种方法可以在不使用两个循环的情况下计算数组中项目的频率。这是在不知道数组大小的情况下。如果我知道数组的大小,我可以使用 switch 而不循环。但我需要更多功能。我认为修改快速排序可能会产生更好的结果。
Array[n];
TwoDArray[n][2];
第一个循环将继续 Array[],而第二个循环是找到元素并增加它在二维数组中的计数。
max = 0;
for(int i=0;i<Array.length;i++){
found= false;
for(int j=0;j<TwoDArray[max].length;j++){
if(TwoDArray[j][0]==Array[i]){
TwoDArray[j][1]+=;
found = true;
break;
}
}
if(found==false){
TwoDArray[max+1][0]=Array[i];
TwoDArray[max+1][1]=1;
max+=;
}
如果您可以发表评论或提供更好的解决方案将非常有帮助。