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

相关推荐
算AI4 小时前
人工智能+牙科:临床应用中的几个问题
人工智能·算法
我不会编程5555 小时前
Python Cookbook-5.1 对字典排序
开发语言·数据结构·python
似水এ᭄往昔6 小时前
【C语言】文件操作
c语言·开发语言
owde6 小时前
顺序容器 -list双向链表
数据结构·c++·链表·list
第404块砖头6 小时前
分享宝藏之List转Markdown
数据结构·list
hyshhhh6 小时前
【算法岗面试题】深度学习中如何防止过拟合?
网络·人工智能·深度学习·神经网络·算法·计算机视觉
蒙奇D索大7 小时前
【数据结构】第六章启航:图论入门——从零掌握有向图、无向图与简单图
c语言·数据结构·考研·改行学it
A旧城以西7 小时前
数据结构(JAVA)单向,双向链表
java·开发语言·数据结构·学习·链表·intellij-idea·idea
杉之7 小时前
选择排序笔记
java·算法·排序算法
烂蜻蜓7 小时前
C 语言中的递归:概念、应用与实例解析
c语言·数据结构·算法