现有 n 个非负整数, a[1], a[2] ... a[n],为了使用选择排序将他们从小到大排序并去重后输出,我们需要不断的从这些数中找到最大的,并且与最后一个元素做交换。为了减少交换元素的次数,我们可以记录最大元素的下标,这样每次仅需要一次交换。请同学们完成一次最大值的寻找,并返回对应下标。下标从1开始。 输入格式 共两行, 第一行,包含一个正整数 n,表示序列的个数。 第二行,包含 n 个非负整数,数与数之间用空格隔开。 输出格式 输出包括一行, 一个整数,最大元素对应的下标。c++
```cpp #include <iostream> using namespace std; int main() { int n; cin >> n; int arr[n]; for (int i = 0; i < n; i++) { cin >> arr[i]; } int maxIndex = 0; // 记录最大元素的下标,从0开始 for (int i = 1; i < n; i++) { if (arr[i] > arr[maxIndex]) { maxIndex = i; } } // 输出下标从1开始 cout << maxIndex + 1 << endl; return 0; } ``` [2026-01-17 14:23:00 | AI问答 | 143点数解答]
相关提问
- [字节豆包] 题目描述 在甜甜圈王国中,每颗甜甜圈都有一个甜度值 S 来衡量其甜蜜程度。根据甜度的不同,甜甜圈被评定为不同的等级,具体规则如下: 如果 S 在 0 到 25 之间(包含 0 和 25 ),输出 "普通甜甜圈"; 如果 S 在 26 到 50 之间(包含 26 和 50 ),输出 "美味甜甜圈"; 如果 S 在 51 到 75 之间(包含 51 和 75 ),输出 "极品甜甜圈"; 如果 S 在 76 到 99 之间(包含 76 和 99 ),输出 "绝世甜甜圈"; 如果 S 等于 100 ,输出 "传说甜甜圈"。 请根据给定的甜度值 S,输出对应的甜甜圈等级名称。 输入格式 一行一个整数 S,表示甜甜圈的甜度值。(243点数解答 | 2025-12-06 18:35:50)60
- [DeepSeek] c++ 给定一个序列 (a_1, a_2, ..., a_n), 定义序列中的一个递增三元组是指三个下标 i, j, k 对应的三个元素 a_i, a_j, a_k,这三个元素满足 a_i < a_j < a_k。 例如序列 (1, 1, 4, 3, 2, 4) 有以下 4 个递增三元组: 1. 下标 1, 4, 6 对应的 1, 3, 4; 2. 下标 1, 5, 6 对应的 1, 2, 4; 3. 下标 2, 4, 6 对应的 1, 3, 4; 4. 下标 2, 5, 6 对应的 1, 2, 4。 注意,可能有下标不同但对应数值相同的三元组,他们应当算成不同的三元组。 给定序列,请问序列中一共有多少个不同的递增三元组。 输入格式 输入第一行包含一个整数 n,表示序列的长度。 第二行包含 n 个整数 a_1, a_2, ..., a_n,表示给定的序列。 输出格式 输出一行,包含一个整数,表示序列中的递增三元组数量。请注意答案可能很大,可能超过 32 位二进制整数的范围,建议使用 64 位二进制整数。 样例输入 6 1 1 4 3 2 4(742点数解答 | 2025-02-25 18:35:56)270
- [DeepSeek] c++ 给定一个序列 (a_1, a_2, ..., a_n), 定义序列中的一个递增三元组是指三个下标 i, j, k 对应的三个元素 a_i, a_j, a_k,这三个元素满足 a_i < a_j < a_k。 例如序列 (1, 1, 4, 3, 2, 4) 有以下 4 个递增三元组: 1. 下标 1, 4, 6 对应的 1, 3, 4; 2. 下标 1, 5, 6 对应的 1, 2, 4; 3. 下标 2, 4, 6 对应的 1, 3, 4; 4. 下标 2, 5, 6 对应的 1, 2, 4。 注意,可能有下标不同但对应数值相同的三元组,他们应当算成不同的三元组。 给定序列,请问序列中一共有多少个不同的递增三元组。 输入格式 输入第一行包含一个整数 n,表示序列的长度。 第二行包含 n 个整数 a_1, a_2, ..., a_n,表示给定的序列。 输出格式 输出一行,包含一个整数,表示序列中的递增三元组数量。请注意答案可能很大,可能超过 32 位二进制整数的范围,建议使用 64 位二进制整数。 样例输入 6 1 1 4 3 2 4(631点数解答 | 2025-02-25 18:40:05)213
- [字节豆包] 给定一个包含 个元素的**整数**序列 ,记作 。 求另一个包含 个元素的待定**整数**序列 ,记 ,使得 且 尽可能的小。 输入 第一行一个整数 ,表示序列元素个数。 第二行 个整数,表示序列 。 输出 一行一个整数,表示 的前提下 的最小值。 样例输入 复制 2 4059 -1782 样例输出 复制 99 提示 对于 的数据, , ,且 序列不全为 来源/分类(746点数解答 | 2026-01-24 13:14:40)31
- [字节豆包] 题目(description): 卫星导航系统(如我国自主研发的北斗卫星导航系统)能实时获取位置、速度、时间等时空信息,在交通运输、农林渔业、气象测报、通信授时、救灾减灾、公共安全等领域都得到了广泛应用。 在应用层面,卫星导航系统一般以报文方式进行数据传输,其中$gprmc是常用报文之一,基本的格式如下: $gprmc,<1>,<2>,<3>,<4>,<5>,<6>,<7>,<8>,<9>,<10>,<11>,<12>*hh <1> utc时间,hhmmss.sss(时分秒.毫秒)格式 <2> 定位状态,a=有效定位,v=无效定位 <3> 纬度ddmm.mmmm(度分)格式 <4> 纬度半球n(北半球)或s(南半球) <5> 经度dddmm.mmmm(度分)格式 <6> 经度半球e(东经)或w(西经) <7> 地面速率(000.0~999.9节) <8> 地面航向(000.0~359.9度,以正北为参考基准) <9> utc日期,ddmmyy(日月年)格式 <10> 磁偏角(000.0~180.0度,前面的0也(385点数解答 | 2025-01-08 03:43:54)433
- [字节豆包] 题目(description): 卫星导航系统(如我国自主研发的北斗卫星导航系统)能实时获取位置、速度、时间等时空信息,在交通运输、农林渔业、气象测报、通信授时、救灾减灾、公共安全等领域都得到了广泛应用。 在应用层面,卫星导航系统一般以报文方式进行数据传输,其中$gprmc是常用报文之一,基本的格式如下: $gprmc,<1>,<2>,<3>,<4>,<5>,<6>,<7>,<8>,<9>,<10>,<11>,<12>*hh <1> utc时间,hhmmss.sss(时分秒.毫秒)格式 <2> 定位状态,a=有效定位,v=无效定位 <3> 纬度ddmm.mmmm(度分)格式 <4> 纬度半球n(北半球)或s(南半球) <5> 经度dddmm.mmmm(度分)格式 <6> 经度半球e(东经)或w(西经) <7> 地面速率(000.0~999.9节) <8> 地面航向(000.0~359.9度,以正北为参考基准) <9> utc日期,ddmmyy(日月年)格式 <10> 磁偏角(000.0~180.0度,前面的0也(346点数解答 | 2025-01-08 03:46:29)428
- [阿里通义] 一个 5×6 的迷宫样例如下: 要求给出从起点(1,1)到终点(3,4)的路径。 为了处理方便,保证最外圈全都为障碍物。 扩展到一般情况,一个 m×n 的迷宫,要求输出从起点(1,1)到终点(m-2,n-2)的路径。 测试实例保证路径是唯一的。 该题要求自行设计一个栈来做。如果设计的是顺序栈,则保证栈的大小不超过 200 个元素。 输入 第一行为两个整数 m 和 n,表示 m×n 的迷宫。 接下来有 m 行,每行有 n 个数(n 个数之间用空格间隔,值 = 0 表示可以通行,值 = 1 表示为障碍物) 输出 输出从起点到终点的路径,每个坐标占一行,坐标间的行号和列号用一个空格间隔。具体格式可参考样例。c++ 源代码(732点数解答 | 2024-11-03 02:34:53)500
- [字节豆包] 小核桃破解了大门的密码,门上开始显示一个进度条。请你帮助小核桃补全代码,输入n,如果n是10的倍数,输出n%;再判断如果n是100,额外输出"完成!"。 输入: 一个整数n(0<=n<=100)。 输出: 如果n是10的倍数,输出n%;再判断如果n是100,额外输出"完成!"。(注意,感叹号为英文感叹号) 输入样例1: 100 输出样例1: 加载100%完成! 输入样例2: 50 输出样例2: 加载50%#include <iostream> using namespace std; int main() { int n; cin >> n; cout << "加载"; if ( ) { if ( ) { } } return 0; }(326点数解答 | 2025-12-13 20:06:10)32
- [字节豆包] 小核桃破解了大门的密码,门上开始显示一个进度条。请你帮助小核桃补全代码,输入n,如果n是10的倍数,输出n%;再判断如果n是100,额外输出"完成!"。 输入: 一个整数n(0<=n<=100)。 输出: 如果n是10的倍数,输出n%;再判断如果n是100,额外输出"完成!"。(注意,感叹号为英文感叹号) 输入样例: 1: 100 输出样例: 1: 加载100%完成! 回答篇幅:简单明了(53点数解答 | 2026-01-10 19:26:25)24
- [字节豆包] 小核桃破解了大门的密码,门上开始显示一个进度条。请你帮助小核桃补全代码,输入n,如果n是10的倍数,输出n%;再判断如果n是100,额外输出"完成!"。 输入: 一个整数n(0<=n<=100)。 输出: 如果n是10的倍数,输出n%;再判断如果n是100,额外输出"完成!"。(注意,感叹号为英文感叹号) 输入样例: 1: 100 输出样例: 1: 加载100%完成!C++14 回答篇幅:简单明了(90点数解答 | 2026-01-10 19:26:42)20
- [百度文心] 小核桃破解了大门的密码,门上开始显示一个进度条。请你帮助小核桃补全代码,输入n,如果n是10的倍数,输出n%;再判断如果n是100,额外输出"完成!"。(用C++) 输入: 一个整数n(0<=n<=100)。 输出: 如果n是10的倍数,输出n%;再判断如果n是100,额外输出"完成!"。(注意,感叹号为英文感叹号) 输入样例1: 100 输出样例1: 加载100%完成! 输入样例2: 50 输出样例2: 加载50% 用时/内存: 1000MS/100MB 在这段代码上编写: #include <iostream> using namespace std; int main() { int n; cin >> n; cout << "加载"; if () { if ( ) { } } return 0; }(231点数解答 | 2026-01-10 19:57:04)26
- [DeepSeek] 小核桃准备使用 a 数组,存储战力为1~10的守卫各有多少个。 即:a[1] 存储战斗力为1的守卫数量,a[2] 存储战斗力为 2 的守卫数量,... 依次类推,a[10] 存储战斗力为 10 的守卫数量。 请你编写程序,使用数组依次存储战力1~10的守卫数量,并按数组下标顺序(从小到大),依次输出每个守卫的战力。 样例1解释: 样例1 输入数据依次表示:战力为1 的守卫有 3 个,战力为3的守卫有 1 个,战力 为4 的守卫有 2 个,战力为 8 的守卫有 2 个,其余战力为2.5.6.7.9.10的守卫数量都为 0。 所以依次输出 三 个 1,一个 3,两个 4,两个 8。 输入: 十个整数,即1~10中每个数的个数。 输出: 一行若干个整数,为从小到大排好序的数,相邻数字之间用空格隔开。 c++(130点数解答 | 2026-01-17 14:11:22)31