鱼C论坛

 找回密码
 立即注册
查看: 1655|回复: 4

[已解决]c语言作业题

[复制链接]
发表于 2021-1-29 17:27:35 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
【问题描述】  输入一组无序的整数,输出其中出现次数最多的整数及其出现次数。


10

0  -50  0  632  5813  -50  9  -50  0  632

【样例输出】

-50 3

0 3

哪里出错了


#include "stdio.h"
#include "string.h"
int main()
{
        int i,j, n;
        int flag,count;
        int arr[100];
        scanf("%d",&n);
        for(i=0;i<n;i++)
        {
            scanf("%d",arr);
        }

         for(i=0;i<n-1;i++)
         {
            for(j=1;j<=n;j++)
            {
                if(arr[i]==arr[j])
                    {

                     flag=arr[i];
                     count=0;
                     count++;
                    }

            }

            {
                printf("%d",flag);
                printf("%d",count);
            }
         }

        return 0;

}
最佳答案
2021-1-29 18:10:36
本帖最后由 jackz007 于 2021-1-29 18:13 编辑
  1. #include <stdio.h>

  2. int main(void)
  3. {
  4.         int i , j , k , n , m , t , arr[100] , dat[100] , cnt[100]                         ;
  5.         scanf("%d" , & n)                                                                  ;
  6.         for(i = 0 ; i < n ; i ++) scanf("%d" , & arr[i])                                   ; // 读入数据
  7.         for(dat[0] = arr[0] , i = m = 1 ; i < n ; i ++) {                                    // 把 arr[n] 中总共 m 个不同数据存入 dat[m] 中
  8.                 for(k = 0 ; k < m && arr[i] != dat[k] ; k ++)                              ; // 把 arr[n] 中总共 m 个不同数据存入 dat[m] 中
  9.                 if (k == m) dat[m ++] = arr[i]                                             ; // 把 arr[n] 中总共 m 个不同数据存入 dat[m] 中
  10.         }                                                                                    // 把 arr[n] 中总共 m 个不同数据存入 dat[m] 中
  11.         for(i = 0 ; i < m - 1 ; i ++) {                                                      // 对 dat[] 按从小到大的顺序排序
  12.                 for(j = i + 1 ; j < m ; j ++) {                                              // 对 dat[] 按从小到大的顺序排序
  13.                         if(dat[i] > dat[j]) {                                                // 对 dat[] 按从小到大的顺序排序
  14.                                 t = dat[i]                                                 ; // 对 dat[] 按从小到大的顺序排序
  15.                                 dat[i] = dat[j]                                            ; // 对 dat[] 按从小到大的顺序排序
  16.                                 dat[j] = t                                                 ; // 对 dat[] 按从小到大的顺序排序
  17.                         }                                                                    // 对 dat[] 按从小到大的顺序排序
  18.                 }                                                                            // 对 dat[] 按从小到大的顺序排序
  19.         }                                                                                    // 对 dat[] 按从小到大的顺序排序
  20.         for(i = 0 ; i < m ; i ++) cnt[i] = 0                                               ; // 初始化计数数组 cnt[m]
  21.         for(i = 0 ; i < m ; i ++) for(j = 0 ; j < n ; j ++) if(dat[i] == arr[j]) cnt[i] ++ ; // 用 cnt[m] 对 arr[n] 进行不同数值的统计计数
  22.         for(k = 0 , i = 1 ; i < m ; i ++) if(cnt[i] > cnt[k]) k = i                        ; // 找到出现次数的多的次数,k 是索引。
  23.         for(i = 0 ; i < m ; i ++) if(cnt[i] == cnt[k]) printf("%d %d\n" , dat[i] , cnt[i]) ; // 把最多次数的数及出现次数统统显示出来
  24. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-1-29 18:10:36 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2021-1-29 18:13 编辑
  1. #include <stdio.h>

  2. int main(void)
  3. {
  4.         int i , j , k , n , m , t , arr[100] , dat[100] , cnt[100]                         ;
  5.         scanf("%d" , & n)                                                                  ;
  6.         for(i = 0 ; i < n ; i ++) scanf("%d" , & arr[i])                                   ; // 读入数据
  7.         for(dat[0] = arr[0] , i = m = 1 ; i < n ; i ++) {                                    // 把 arr[n] 中总共 m 个不同数据存入 dat[m] 中
  8.                 for(k = 0 ; k < m && arr[i] != dat[k] ; k ++)                              ; // 把 arr[n] 中总共 m 个不同数据存入 dat[m] 中
  9.                 if (k == m) dat[m ++] = arr[i]                                             ; // 把 arr[n] 中总共 m 个不同数据存入 dat[m] 中
  10.         }                                                                                    // 把 arr[n] 中总共 m 个不同数据存入 dat[m] 中
  11.         for(i = 0 ; i < m - 1 ; i ++) {                                                      // 对 dat[] 按从小到大的顺序排序
  12.                 for(j = i + 1 ; j < m ; j ++) {                                              // 对 dat[] 按从小到大的顺序排序
  13.                         if(dat[i] > dat[j]) {                                                // 对 dat[] 按从小到大的顺序排序
  14.                                 t = dat[i]                                                 ; // 对 dat[] 按从小到大的顺序排序
  15.                                 dat[i] = dat[j]                                            ; // 对 dat[] 按从小到大的顺序排序
  16.                                 dat[j] = t                                                 ; // 对 dat[] 按从小到大的顺序排序
  17.                         }                                                                    // 对 dat[] 按从小到大的顺序排序
  18.                 }                                                                            // 对 dat[] 按从小到大的顺序排序
  19.         }                                                                                    // 对 dat[] 按从小到大的顺序排序
  20.         for(i = 0 ; i < m ; i ++) cnt[i] = 0                                               ; // 初始化计数数组 cnt[m]
  21.         for(i = 0 ; i < m ; i ++) for(j = 0 ; j < n ; j ++) if(dat[i] == arr[j]) cnt[i] ++ ; // 用 cnt[m] 对 arr[n] 进行不同数值的统计计数
  22.         for(k = 0 , i = 1 ; i < m ; i ++) if(cnt[i] > cnt[k]) k = i                        ; // 找到出现次数的多的次数,k 是索引。
  23.         for(i = 0 ; i < m ; i ++) if(cnt[i] == cnt[k]) printf("%d %d\n" , dat[i] , cnt[i]) ; // 把最多次数的数及出现次数统统显示出来
  24. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-1-29 19:52:23 | 显示全部楼层
1.为啥声明变量不初始化?
2.scanf("%d",&n);scanf("%d",arr);把你这个改成scanf_s应该就可以了,边界安全问题,应该是编译器阻止了

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-1-29 22:47:18 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-1-29 23:00:52 | 显示全部楼层
        你的理解是正确的,有这个学习态度一定能学好,加油!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-5-2 02:53

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表