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

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语言卸载之后无法重装,显示电脑存在下载某些较大二进制文件行为,怎么办
  • ¥15 java 的protected权限 ,问题在注释里
  • ¥15 这个是哪里有问题啊?
  • ¥15 关于#vue.js#的问题:修改用户信息功能图片无法回显,数据库中只存了一张图片(相关搜索:字符串)
  • ¥15 texstudio的问题,
  • ¥15 spaceclaim模型变灰色
  • ¥15 求一份华为esight平台V300R009C00SPC200这个型号的api接口文档
  • ¥15 字符串比较代码的漏洞
  • ¥15 欧拉系统opt目录空间使用100%
  • ¥15 ul做导航栏格式不对怎么改?