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

相关推荐
LaoZhangGong1239 分钟前
STM32的“Unique device ID“能否修改?
c语言·经验分享·stm32·单片机·嵌入式硬件
万兴丶36 分钟前
Unity 适用于单机游戏的红点系统(前缀树 | 数据结构 | 设计模式 | 算法 | 含源码)
数据结构·unity·设计模式·c#
维齐洛波奇特利(male)1 小时前
(动态规划 完全背包 **)leetcode279完全平方数
算法·动态规划
程序员东min1 小时前
数据结构:实验题目:单链表归并。将两个非递减次序排列的单链表归并为一个非递增次序排列的单链表,并计算表长。要求利用原来两个单链表的结点存放合并后的单链表。
数据结构
黄雪超2 小时前
深入HBase——核心组件
数据结构·数据库·hbase
项目申报小狂人2 小时前
改进收敛因子和比例权重的灰狼优化算法【期刊论文完美复现】(Matlab代码实现)
开发语言·算法·matlab
让我们一起加油好吗2 小时前
【排序算法】六大比较类排序算法——插入排序、选择排序、冒泡排序、希尔排序、快速排序、归并排序【详解】
c语言·算法·排序算法
夏末秋也凉2 小时前
力扣-贪心-53 最大子数组和
数据结构·算法·leetcode
liruiqiang053 小时前
机器学习 - 投票感知器
人工智能·算法·机器学习
老猿讲编程5 小时前
安全C语言编码规范概述
c语言·开发语言·安全