如果I inter-array,例如[1,1,1,2]程序将打印:
数字1出现3次。
数字1出现3次。
数字1出现3次。
数字2出现1次。
它应该打印:
数字1出现3次。
数字2出现1次。
如何解决此问题
#include <stdio.h>
int main() {
int i,arr[1000],counters[1001]={0},n;
printf("Enter numbers: n");
for(i=0;i<100;i++){
scanf("%d", &arr[i]);
if(arr[i]==-1) break;
if(arr[i]<0||arr[i]>100){
printf("Numbers must be between 0 and 100n");
i--;
}
}
n=i;
for(i=0;i<n;i++){
counters[arr[i]]++;
}
for(i=0;i<n;i++){
printf("Number %d appears: %d timesn", arr[i], counters[arr[i]]);
}
return 0;
}
您正在循环输入的总数,因此在这种特殊情况下,您将获得4行输出。然而,由于您使用的非负整数数量相对较少,因此可以通过使索引表示输入来简化程序,如下所示:
#include <stdio.h>
int main() {
int arr[101]={0}, n;
printf("Enter numbers (end with -1): n");
while (1) {
scanf("%d", &n);
if(n==-1) break;
if(n<0 || n>100) {
printf("Numbers must be between 0 and 100n");
continue;
}
arr[n]++;
}
for(n=0;n<=100;n++){
if (arr[n]) printf("Number %d appears: %d timesn", n, arr[n]);
}
return 0;
}
不要遍历多个出现次数相同的数组,而是将迭代器增加出现次数,立即跳到下一个数字:
for(i=0;i<n;i+= counters[arr[i]]){
printf("Number %d appears: %d timesn", arr[i], counters[arr[i]]);
}
遍历计数器数组并打印计数器>0
for (i = 0; i < 100; i++)
{
if (counters[i])
{
printf("Number %d appears: %d timesn", i, counters[i]);
}
}