人类与发展 2022-05-05 15:36 采纳率: 100%
浏览 46
已结题

C语言,:输入一堆[0,9]的数,输入-1结束,然后输出每个数的出现次数;自己写的方法有问题希望得到解答

问题遇到的现象和发生背景

题目如标题所示,自己的方法写的方法比较臃肿,也存在不规范的地方,但逻辑上我认为可以接受,不过结果完全乱套,主要我不太确定是哪一块出了问题,自我感觉是函数定义那一块没有弄好,以及因为这里想做变长数组,不知道如何处理数组的长度,只能先定义个100个,也没有做越限的处理。希望能知晓问题之所在,感激不尽!

问题相关代码,请勿粘贴截图

void judgeA(int a[] , int length, int number);//声明判断数组内number 出现次数的函数
int main(){ //输入数量不确定的[0,9]范围内的整数,-1表示结束
int pr ; //输入数字的暂存变量
int length = 100 ;
int a[length] ; //存数的数组
int i = 0;
scanf("%d\n",&pr);
while(pr != -1){ //循环输入数字,输入-1结束
abc[i] = pr;
i++ ;
scanf("%d\n",&pr);
}
int number ;
for(number=0 ; number<10 ; number++){ //循环判断[0,9]的数字出现次数
judgeA(a,length,number);
}
return 0 ;
}
void judgeA(int a[] , int length, int number){ //参数为一个数组,数组长度,即将要判断的数字
int i ;
int count = 0; //记数的变量
for(i=0 ; i<length ; i++){ //遍历数组
if (a[i] == number){
count++;
}
}
if (count != 0){
printf("数字%d出现的次数是%d\n",number,count); //假如出现的次数不是0,那么就输出这条语句
}
return ;
}

  • 写回答

2条回答 默认 最新

  • qzjhjxj 2022-05-05 16:40
    关注

    题主的代码修改如下,见注释,供参考:

    #include <stdio.h>
    #define length 1000  //修改
    void judgeA(int a[], int len, int number);//声明判断数组内number 出现次数的函数
    int main() { //输入数量不确定的[0,9]范围内的整数,-1表示结束
        int pr; //输入数字的暂存变量
        int a[length]; //存数的数组
        int i = 0;
        scanf("%d", &pr);  //scanf("%d\n", &pr);  修改
        while (pr != -1) { //循环输入数字,输入-1结束
            a[i] = pr;
            i++;
            scanf("%d", &pr); //scanf("%d\n", &pr);
        }
        int number;
        for (number = 0; number < 10; number++) { //循环判断[0,9]的数字出现次数
            judgeA(a, i, number);  //修改     
            //judgeA(a, length, number);
        }
        return 0;
    }
    void judgeA(int a[], int len, int number) { //参数为一个数组,数组长度,即将要判断的数字
        int i;
        int count = 0; //记数的变量
        for (i = 0; i < len; i++) { //遍历数组
            if (a[i] == number) {
                count++;
            }
        }
        if (count != 0) {
            printf("数字%d出现的次数是%d\n", number, count); //假如出现的次数不是0,那么就输出这条语句
        }
        return;
    }
    
    

    题主考虑的太复杂了,提供另外一种写法,供参考:

    #include <stdio.h>
    int main()
    {
        int  n, i, a[10] = { 0 };
        while (scanf("%d", &n) == 1 && n != -1) a[n]++;
        for (i = 0; i < 10; i++)
            printf("数字%d出现的次数是%d\n", i, a[i]);
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 5月13日
  • 已采纳回答 5月5日
  • 创建了问题 5月5日

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog