week2-[一维数组]最大元素

week2-[一维数组]最大元素

题目描述

给定 NNN 个整数A1,A2,...,ANA_1,A_2,\ldots,A_NA1,A2,...,AN。请求出这 NNN 个数的最大值,并找出最大值的出现位置(A1A_1A1 的位置为 111,A2A_2A2 的位置为2,依此类推)。如果同时存在多个最大的数,按从小到大的顺序输出最大的数出现的所有位置。

输入格式

读入包括 222 行。第一行只有 111 个整数 NNN,表示数的个数。第二行包括 NNN 个整数 A1,A2,...,ANA_1,A_2,\ldots,A_NA1,A2,...,AN。

输出格式

输出 222 行,第一行包括一个整数,表示 A1,A2,...,ANA_1,A_2,\ldots,A_NA1,A2,...,AN 的最大值。 第二行包含若干个整数,表示最大值在 A1,A2,...,ANA_1,A_2,\ldots,A_NA1,A2,...,AN 中的所有出现位置(每两个数之间用恰好一个空格隔开)。

样例 #1

样例输入 #1

复制代码
8
1 3 5 9 2 6 4 2

样例输出 #1

复制代码
9
4

样例 #2

样例输入 #2

复制代码
9
2 5 2 6 8 5 11 3 11

样例输出 #2

复制代码
11
7 9

样例 #3

样例输入 #3

复制代码
5
10 10 10 8 10

样例输出 #3

复制代码
10
1 2 3 5

提示

样例解释1

1,3,5,9,2,6,4,21, 3, 5, 9, 2, 6, 4, 21,3,5,9,2,6,4,2 中的最大值为 999,出现在第 444 个位置。

样例解释2

2,5,2,6,8,5,11,3,112, 5, 2, 6, 8, 5, 11, 3, 112,5,2,6,8,5,11,3,11 中的最大值为 111111,出现在第 777 个位置和第 999 个位置。

样例解释3

10,10,10,8,1010, 10, 10, 8, 1010,10,10,8,10 中的最大值为 101010,出现在第 1,2,3,51,2,3,51,2,3,5 个位置。

数据范围

对于所有数据,1≤N≤500,−100≤Ai≤1001 \le N \le 500, -100 \le A_i \le 1001≤N≤500,−100≤Ai≤100。

1. 阅读题目

  • 输入:
    • 第 1 行:整数 NNN
    • 第 2 行:NNN 个整数 A1,A2,...,ANA_1,A_2,\dots,A_NA1,A2,...,AN
  • 输出:
    1. 第一行:最大值
    2. 第二行:最大值出现的所有位置(从 1 开始),按出现顺序输出

2. 分析问题

思路很直接:

  1. 初始化 maxVal = A[0]pos 空数组保存位置。
  2. 遍历数组:
    • 如果当前元素 > maxVal → 更新 maxVal,清空 pos,记录当前位置
    • 如果当前元素 == maxVal → 在 pos 追加当前位置
  3. 输出 maxValpos

注意事项:

  • 位置从 1 开始 ,所以索引 i+1 保存到 pos
  • 数据量小(N≤500N \le 500N≤500),可以直接用数组保存位置。

3. C++ 代码实现(兼容低版本)

c++ 复制代码
#include <iostream>
using namespace std;

int main() {
    int N;
    cin >> N;

    int A[505];      // 保存输入数组
    int pos[505];    // 保存最大值出现的位置
    int maxVal = -101; // 初始小于最小可能值
    int cnt = 0;     // 记录最大值出现次数

    for (int i = 0; i < N; i++) {
        cin >> A[i];
        if (A[i] > maxVal) {
            maxVal = A[i];
            cnt = 1;
            pos[0] = i + 1; // 保存位置,从1开始
        } else if (A[i] == maxVal) {
            pos[cnt] = i + 1;
            cnt++;
        }
    }

    // 输出最大值
    cout << maxVal << "\n";

    // 输出所有位置
    for (int i = 0; i < cnt; i++) {
        if (i > 0) cout << " ";
        cout << pos[i];
    }
    cout << "\n";

    return 0;
}

4. 示例运行

输入:

复制代码
9
2 5 2 6 8 5 11 3 11

输出:

复制代码
11
7 9

✅ 总结

  • 遍历数组同时统计最大值和位置
  • 出现新最大值时清空位置数组
  • 相同最大值追加位置
  • 时间复杂度 O(N)O(N)O(N),空间复杂度 O(N)O(N)O(N)
相关推荐
风筝在晴天搁浅6 分钟前
字节高频题 小于n的最大数
算法
LabVIEW开发8 分钟前
LabVIEW水力机组空蚀在线监测
算法·labview·labview知识·labview功能·labview程序
AI科技星13 分钟前
科幻艺术书本封面:《全域数学》第一部·数术本源 第三卷 代数原本(P95-141)完整五级目录【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
风筝在晴天搁浅15 分钟前
LeetCode 92.反转链表Ⅱ
算法·leetcode·链表
王老师青少年编程29 分钟前
csp信奥赛C++高频考点专项训练之贪心算法 --【贪心与二分判定】:数列分段 Section II
c++·算法·贪心·csp·信奥赛·二分判定·数列分段 section ii
zh_xuan31 分钟前
libcurl调用https接口
c++·libcurl
就叫飞六吧33 分钟前
QT写一个桌面程序exe并动态打包基本流程(c++)
开发语言·c++
蜡笔小马34 分钟前
1.c++设计模式-工厂模式
c++
V搜xhliang02461 小时前
OpenClaw科研全场景用法:从文献到实验室的完整自动化方案
运维·开发语言·人工智能·python·算法·microsoft·自动化
汉克老师1 小时前
GESP2025年3月认证C++五级( 第三部分编程题(2、原根判断))
c++·算法·模运算·gesp5级·gesp五级·原根·分解质因数