C. Assembly via Remainders

C.通过余数组装

每次测试时限:2 秒

每次测试的内存限制:256 兆字节

输入:标准输入

输出:标准输出




思路分析

我们用arr数组存放输入的数据,用brr代表代表答案数组,我们可以看到答案的第一位是都是arr的首位+1,然后我们观察可得,答案等于答案数组的前一位加是对于的输入数据即:brr[i + 1] = brr[i]+ arr[i];

如果这样做的话,第五组数据会得到2 3 8,这样第二号余数是2,就不符合题目给的5的条件了因此我们需要这样写,因为这个数太小了不行,所以要让他大一点

cpp 复制代码
            while(brr[i + 1] <= arr[i + 1])
            {
                brr[i + 1] += brr[i];
            }
cpp 复制代码
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
int t,n,k;
int arr[550];
int brr[550];
int main()
{
    cin >> t;
    while (t--)
    {
        cin >> n;
        for (int i = 0; i < n - 1; i++) cin >> arr[i];
        brr[0] = arr[0]+ 1;
        for (int i = 0; i < n - 1; i++)
        {
           // k = 2;
            brr[i + 1] = brr[i]+ arr[i];
            while(brr[i + 1] <= arr[i + 1])
            {
                brr[i + 1] += brr[i];
            }
 
        }
        for (int i = 0; i < n; i++)
            cout << brr[i] << " ";
        cout << endl;
    }
 
 
    return 0;
}
相关推荐
你也向往长安城吗1 小时前
推荐一个三维导航库:three-pathfinding-3d
javascript·算法
蒋星熠1 小时前
C++零拷贝网络编程实战:从理论到生产环境的性能优化之路
网络·c++·人工智能·深度学习·性能优化·系统架构
★YUI★1 小时前
学习游戏制作记录(玩家掉落系统,删除物品功能和独特物品)8.17
java·学习·游戏·unity·c#
百度智能云1 小时前
VectorDB+FastGPT一站式构建:智能知识库与企业级对话系统实战
算法
CHANG_THE_WORLD1 小时前
# C++ 中的 `string_view` 和 `span`:现代安全视图指南
开发语言·c++
雨落倾城夏未凉1 小时前
9.c++new申请二维数组
c++·后端
谷宇.1 小时前
【Unity3D实例-功能-拔枪】角色拔枪(二)分割上身和下身
游戏·unity·c#·游戏程序·unity3d·游戏开发·游戏编程
雨落倾城夏未凉2 小时前
8.被free回收的内存是立即返还给操作系统吗?为什么?
c++·后端
雨落倾城夏未凉2 小时前
6.new和malloc的区别
c++·后端
郝学胜-神的一滴2 小时前
深入理解QFlags:Qt中的位标志管理工具
开发语言·c++·qt·程序人生