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函数来输入数字,你可以根据具体情况自行修改输入方式和范围。

相关推荐
小刘|20 分钟前
《Java 实现希尔排序:原理剖析与代码详解》
java·算法·排序算法
jjyangyou24 分钟前
物联网核心安全系列——物联网安全需求
物联网·算法·安全·嵌入式·产品经理·硬件·产品设计
xinghuitunan39 分钟前
蓝桥杯顺子日期(填空题)
c语言·蓝桥杯
van叶~41 分钟前
算法妙妙屋-------1.递归的深邃回响:二叉树的奇妙剪枝
c++·算法
Half-up42 分钟前
C语言心型代码解析
c语言·开发语言
简简单单做算法42 分钟前
基于Retinex算法的图像去雾matlab仿真
算法·matlab·图像去雾·retinex
云卓SKYDROID1 小时前
除草机器人算法以及技术详解!
算法·机器人·科普·高科技·云卓科技·算法技术
懒大王就是我1 小时前
C语言网络编程 -- TCP/iP协议
c语言·网络·tcp/ip
半盏茶香1 小时前
【C语言】分支和循环详解(下)猜数字游戏
c语言·开发语言·c++·算法·游戏
徐子童1 小时前
双指针算法习题解答
算法