c语言编写程序,找出出现次数最高的数字 数字范围1-1000 时间复杂度不超过O(n)

以下是一个C语言程序,使用O(n)的时间复杂度找出出现次数最高的数字:

c 复制代码
#include <stdio.h>

int main() {
    int count[1001] = {0};  // 用于记录每个数字出现的次数
    int maxNum = -1;  // 出现次数最高的数字
    int maxCount = 0;  // 最高出现次数

    // 输入数字范围
    int start = 1;
    int end = 1000;
    int num;

    // 输入数字,并更新次数统计
    while (scanf("%d", &num) == 1) {
        if (num >= start && num <= end) {
            count[num]++;
            if (count[num] > maxCount) {
                maxCount = count[num];
                maxNum = num;
            }
        }
    }

    // 输出结果
    printf("出现次数最高的数字是:%d,出现次数:%d\n", maxNum, maxCount);

    return 0;
}

该程序使用一个长度为1001的数组count来记录每个数字的出现次数。遍历输入的数字,将数字作为count数组的索引,更新对应位置的次数统计。同时,如果当前数字的出现次数超过当前最高次数,就更新最高次数和最高次数对应的数字。最后输出最高次数和对应的数字。

注意,该程序使用了scanf函数来输入数字,你可以根据具体情况自行修改输入方式和范围。

相关推荐
haoly19891 小时前
数据结构和算法篇-线性查找优化-移至开头策略
数据结构·算法·移至开头策略
迎風吹頭髮2 小时前
UNIX下C语言编程与实践53-UNIX 共享内存控制:shmctl 函数与共享内存管理
服务器·c语言·unix
学Linux的语莫5 小时前
机器学习数据处理
java·算法·机器学习
逆小舟5 小时前
【C/C++】指针
c语言·c++·笔记·学习
earthzhang20215 小时前
【1007】计算(a+b)×c的值
c语言·开发语言·数据结构·算法·青少年编程
迎風吹頭髮6 小时前
UNIX下C语言编程与实践63-UNIX 并发 Socket 编程:非阻塞套接字与轮询模型
java·c语言·unix
奔跑吧邓邓子7 小时前
【C语言实战(6)】解锁C语言循环密码:for循环实战探秘
c语言·实战·for循环
GilgameshJSS7 小时前
STM32H743-ARM例程15-RTC
c语言·arm开发·stm32·实时音视频
2301_803554527 小时前
C++联合体(Union)详解:与结构体的区别、联系与深度解析
java·c++·算法
pu_taoc7 小时前
深入剖析:基于epoll与主从Reactor模型的高性能服务器设计与实现
服务器·c语言·c++·vscode