【思维构造】Find The Array—CF1463B

Find The Array---CF1463B

思路

我太菜了,这么简单的思路都没有想到。。。

分别计算 a a a 数组中下标为奇数的所有元素的和 sum_odd 和下标为偶数的所有元素的和 sum_even

如果 sum_odd < sum_even,将 a a a 中的所有下标为奇数的元素全部换成 1 1 1 后的 a a a 就是需要求的 b b b 数组;

如果 sum_odd > sum_even,将 a a a 中的所有下标为偶数的元素全部换成 1 1 1 后的 a a a 就是需要求的 b b b 数组;

C o d e Code Code

cpp 复制代码
#include <bits/stdc++.h>
#define int long long
#define sz(a) ((int)a.size())
#define all(a) a.begin(), a.end()
using namespace std;
using PII = pair<int, int>;
using i128 = __int128;
const int N = 2e5 + 10;

int n;
int a[N];

void solve() {
	cin >> n;
	for (int i = 1; i <= n; i ++) cin >> a[i];
	
	int sum_odd = 0, sum_even = 0;
	for (int i = 1; i <= n; i ++) {
		if (i % 2) {
			sum_odd += a[i];
		} else {
			sum_even += a[i];
		}
	}
	
	for (int i = 1 + (sum_even < sum_odd); i <= n; i += 2) {
		a[i] = 1;
	}
	for (int i = 1; i <= n; i ++) {
		cout << a[i] << ' ';
	}
	cout << "\n";
}

signed main() {
	ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
	int T = 1;
	cin >> T; cin.get();
	while (T --) solve();
	return 0;
}
相关推荐
nianniannnn19 小时前
力扣 76. 最小覆盖子串
c++·算法·leetcode
灰色小旋风19 小时前
力扣K个一组翻转链表C++
c++·算法·leetcode
manyikaimen19 小时前
博派智能-运动控制技术-RTCP-五轴联动
c++·图像处理·qt·算法·计算机视觉·机器人·c#
Darkwanderor19 小时前
搜索优化——启发式搜索和A*算法
c++·算法·启发式搜索·a星搜索
耶叶19 小时前
BIT-TPS:关于实验4数学库完善与设计重构的详细解读
c++·bit·旋风
承渊政道20 小时前
【优选算法】(实战突破字符串:经典题型与解题模板)
c语言·数据结构·c++·笔记·学习·算法·容器
Hello eveybody20 小时前
图论简述+图论考试要点(C++)
c++·深度优先·图论
第二只羽毛20 小时前
C++高性能内存池6(面试题)
大数据·开发语言·c++
努力的章鱼bro20 小时前
操作系统-net
c++·操作系统·dma·risc-v
故事和你9120 小时前
洛谷-算法1-1-模拟与高精度4
开发语言·数据结构·c++·算法·蓝桥杯·动态规划