吴冰燕 2022-12-10 00:43 采纳率: 84%
浏览 51
已结题

C++ 排排站 难度:初阶

题目背景
小T作为班长,要筹备这次的主题班会。班主任给了小T几个任务。
题目描述
主题班会结束后会进行一个小游戏。首先挑选 n 名同学出来组成队伍,排成一排,并且每个人在背后贴一张写有数字的卡片 ai(数字可能不同)。
然后从剩下的学生中随机挑选一个加入队伍,允许他自由选择要加入到队伍的哪个位置。加入队伍后,奖励给这个学生他左右两边同学背后卡片数字之和同等数量的糖果。
请问这名学生最多能获得几个糖果?
输入格式
第一行一个整数 n,表示站成一排的学生人数
接下来 n 行,每行一个整数,对应从左到右每个学生背后卡片的数字 ai。
输出格式
一个整数,表示这名学生最多能获得的糖果数量。
样例数据
输入样例 #1
6
8
3
4
8
2
9
输出样例 #1
12
样例 #1 解释
这名学生选择站在 4 和 8 这两名学生之间,能获得最多糖果。
部分分设置
程序在部分分规定的范围内能正确计算并输出答案,即可获得该部分分数

img

数据范围
对于全部数据,1≤n≤1000,0≤ai≤1000。

  • 写回答

3条回答 默认 最新

  • 关注

    就是找临近的两个数和最大的

    img

    代码:

    #include <iostream>
    using namespace std;
    int main()
    {
        int n,i,t;
        int a[1010];
        int maxn = 0;
        cin >> n;
        for(i=0;i<n;i++)
            cin >> a[i];
        if(n==1)
            cout << a[0];
        else if(n==2)
            cout << a[0]+a[1];
        else
        {
            maxn = a[0]+a[1];
            for(i=2;i<n;i++)
            {
                if(a[i]+a[i-1] > maxn)
                    maxn = a[i]+a[i-1];
            }
            cout << maxn;
        }
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 12月23日
  • 已采纳回答 12月15日
  • 创建了问题 12月10日

悬赏问题

  • ¥15 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值