Codeforces Round 900 (Div. 3)

Dashboard - Codeforces Round 900 (Div. 3) - Codeforces

C. Vasilije in Cacak

用等差数列求出能够构造出的最小值与最大值,判断x是否在这个范围内,如果在则能被构造出,此为结论,能被构造出的数为最小值与最大值之间的每一个数(如果有数小就往后移1)

一段数的和:(首项 + 末项) * 项数 / 2

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int solve()
{
	ll n, k, x, minn, maxx;
	cin >> n >> k >> x;
	minn = (1 + k) * k / 2;
	maxx = (n - k + 1 + n) * k / 2;
	if(x >= minn && x <= maxx)cout << "YES" << '\n';
	else cout << "NO" << '\n';
}
int main()
{
	int t;
	cin >> t;
	while(t --)
	{
		solve();	
	} 
	return 0;
}

D. Reverse Madness

将x看作一点,ri + li - x看作另一点,由于要翻转多次,可以每翻转一下记录一次,如果翻转了偶数次相当于没有翻转,不然就相当于翻转一次

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
void solve()
{
	int n, k, q, x;
	string s;
	cin >> n >> k;
	cin >> s;
	vector<int> l(k + 10, 0) , r(k + 10, 0), cnt (n + 1);
	for(int i = 1; i <= k; i ++)
	{
		cin >> l[i];
		l[i] --;
	}
	for(int i = 1; i <= k; i ++)
	{
		cin >> r[i];
		r[i] --;
	}
	cin >> q;
	while(q --)
	{
		cin >> x;
		cnt[x - 1] ++;
	}
	for(int i = 1; i <= k; i ++)
	{
		int ll = l[i];
		int rr = r[i];
		int sum = 0;
		for(int j = ll; j <= (ll + rr) / 2; j ++)
		{
			sum += cnt[j] + cnt[rr + ll - j];
			if(sum & 1)swap(s[j], s[rr + ll -j]);
		}
	}
	cout << s << '\n';
}
int main()
{
	ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
	int t;
	cin >> t;
	while(t --)
	{
		solve();
	}
	return 0;
}
相关推荐
岁忧10 分钟前
(LeetCode 每日一题) 3541. 找到频率最高的元音和辅音 (哈希表)
java·c++·算法·leetcode·go·散列表
pusue_the_sun18 分钟前
每日算法题推送
算法·双指针
JasmineX-129 分钟前
数据结构——顺序表(c语言笔记)
c语言·开发语言·数据结构·笔记
KyollBM32 分钟前
【Luogu】P9809 [SHOI2006] 作业 Homework (根号算法)
算法
小六子成长记33 分钟前
【C++】:list容器全面解析(超详细)
c++·windows·list
jmxwzy37 分钟前
leetcode274.H指数
算法
IT灰猫1 小时前
C++轻量级配置管理器升级版
开发语言·c++·设计模式·配置管理·ini解析
纪元A梦1 小时前
贪心算法应用:信用评分分箱问题详解
java·算法·贪心算法
I'm a winner2 小时前
第五章:Python 数据结构:列表、元组与字典(一)
开发语言·数据结构·python
过河卒_zh15667662 小时前
9.13AI简报丨哈佛医学院开源AI模型,Genspark推出AI浏览器
人工智能·算法·microsoft·aigc·算法备案·生成合成类算法备案