首页 > 其他分享 >CEOI 2021

CEOI 2021

时间:2022-11-01 21:35:27浏览次数:45  
标签:cout int CEOI pb vis 2021 ans id

CEOI 2021

\(pts\):64 + 0 + 4

\(T1 : 64pts\)

首先我们肯定知道对于相同的数,一定是放在一起才是最优的,随意我们对于每段查询的区间要保证有序,然后我们发现,每个数出现的位置不同,他对答案的贡献也就不同,我们的想法是让答案最小,那么我们对于每个位置对答案的贡献一定要均摊,所以我们考虑错位排开,其实也可以打表找规律(到 \(6\) 就行了)。然后对于所有 \(q = 1\) 的就可以做出来了

点击查看代码
#include<bits/stdc++.h>
#define int long long
using namespace std;
const int M = 3e5 + 7;
int a[M] , vis[M] , b[M] , t , size;
struct Query{int l , r , id;} Q[M];
bool cmp(Query a , Query b) {
	return belong[a.l] == belong[b.l] ? a.r < b.r : belong[a.l] < belong[b.l];
}
signed main () {
//	freopen("data.in","r",stdin);
//	freopen("data.ans","w",stdout);
	ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
	int n , q; cin >> n >> q;
	for(int i = 1; i <= n; ++ i) cin >> a[i];
	if(q == 1) {
		int l , r; cin >> l >> r;
		sort(a + l , a + r + 1);
		int ans = 0 , cnt = 0 , sum = 0;
		for(int i = l; i <= r; ++ i) {if(!vis[a[i]]) cnt ++ ;vis[a[i]] ++; sum += cnt;}
		sort(vis + 1 , vis + 300000 + 1 , greater<int>());
		int  L = l , R = r , tot = 0;
		for(int i = cnt; i >= 1; -- i) {
			tot ++;
			if(tot & 1)while(vis[i]) a[L] = i , vis[i] -- , L ++;
			else while(vis[i]) a[R] = i , vis[i] -- , R --;
		}
		memset(vis , 0 , sizeof vis);
		cnt = 0 , sum = 0;
		for(int i = l; i <= r; ++ i) {if(!vis[a[i]]) cnt ++ ;vis[a[i]] ++; sum += cnt;}	
		for(int i = l; i <= r; ++ i) {
			ans += sum;
			vis[a[i]] --;
			if(! vis[a[i]]) sum -= r - i + 1;
			else sum --;
		}
		return cout << ans << '\n' , 0;
	}
	
}

\(T2 : 0pts\)

\(T2\) 直接爆零了,一点思路都没有

\(T3\) : \(4pts\)

我们首先对于链的情况进行分析,我们可以知道在一条链上的话,一定是有解的,那么考虑如何让答案最优,我们发现如果我们遍历两边这条链的话,那么一定是能找到 \(Branko\) 的,但是这样是最优的嘛,我们发现,链两端的对答案没有影响,所以可以直接排除掉,故为链的答案为 \((n - 2) * 2\)。那么在考虑一般情况,那么也就是在链上多几条支链,和环。我们先来考虑环的情况,如果说这个图中有环的话,那么是一定不能找到 \(Branko\) 的。那么最后再来考虑支链的情况,因为我们知道一个长度为 \(2\) 的链是一定能找到的,那么对于长度为 \(3\) 及以上的呢。那么我们发现如果说一条支链大于 \(2\) 了,那么 \(Ankica\) 就没办法继续往下猜了, 因为这样\(Branko\) 可能就会跑到别的支链,就造成了无解,所以只要找到树的直径,再找支链即可。

点击查看代码
#include<bits/stdc++.h>
#define int long long
#define pb push_back
using namespace std;
const int M = 1e3 + 7;
int f[M] , id[M] , vis[M] , dep[M] , Max , pos;
vector<int> e[M] , a[M];
void dfs(int x , int fa , int sum) {
	if(Max < sum) Max = sum , pos = x;
	f[x] = fa;
	for(auto i : e[x]) {
		if(i == fa) continue;
		dfs(i , x , sum + 1);	
	}
}
void dfs_1(int x , int fa) {
	dep[x] = 1;
	for(auto i : e[x]) {
		if(i == fa) continue;
		dfs_1(i , x);
		dep[x] = dep[i] + 1;
	}
}
signed main () {
	ios::sync_with_stdio(0),cin.tie(0);
	int n , m; cin >> n >> m;
	if(n == 1) return cout << "YES" << '\n' << 1 << '\n' << 1 << '\n' , 0;
	if(n == 2) return cout << "YES" << '\n' << 2 << '\n' << "1 1" << '\n' , 0;
	for(int i = 1; i <= m; ++ i) {
		int u ,v; cin >> u >> v;
		e[u].pb(v) , e[v].pb(u);
	}	
	
	if(m >= n) return cout << "NO" << '\n' , 0;
	int pos1;
	dfs(1 , 0 , 0) , memset(f , 0 , sizeof f) , Max = 0 , pos1 = pos, dfs(pos , 0 , 0);
	int cnt = 0;
	for(int i = pos; i ; i = f[i]) {
		id[++ cnt] = i; vis[i] = 1;
	}
	for(int i = 1; i <= n; ++ i) {
		if(! vis[i] && vis[f[i]]) {
			dfs_1(i , f[i]);
			if(dep[i] >= 3) return cout << "NO" << '\n' , 0;	
			if(dep[i] > 1) a[f[i]].pb(i);
		}
	}
	cout << "YES" << '\n';
	vector<int> ans;
	for(int i = 2; i < cnt; ++ i) {
		ans.pb(id[i]);
		for(auto j : a[id[i]]) {
			ans.pb(j); ans.pb(id[i]);
		}
	}
	for(int i = cnt - 1; i > 1; -- i) {
		ans.pb(id[i]);
		for(auto j : a[id[i]]) {
			ans.pb(j);ans.pb(id[i]);
		}
	}
	cout << ans.size() << '\n';
	for(auto i : ans) cout << i << ' ';
	return 0;	
}

标签:cout,int,CEOI,pb,vis,2021,ans,id
From: https://www.cnblogs.com/L3067545513/p/16849228.html

相关文章

  • 2021 ICPC 沈阳站
    CodeforcesBBitwiseExclusive-ORSequenceDescription给定\(n\)个数和\(m\)个限制:\(a_u\a_v\w\),要求\(a_u\bigoplusa_v=w\)求这\(n\)个数的和的最小值。S......
  • 2021ICPC济南
    2021ICPC济南时隔一年再来补题,金牌题以下还是可以补的。C(组合数学,DP,贪心)题意两人每次从序列中取数字,希望自己拿到的数字和最大。求可行的操作序列方案数。思路看起来......
  • APACHE_CVE-2021-40438-SSRF漏洞分析复现
    影响版本v2.4.48及以下版本该版本中mod_proxy模块存在一处逻辑错误,导致攻击者可以控制反向代理服务器的地址,进而导致SSRF漏洞。该漏洞影响范围较广,危害较大,利用简单,目前......
  • The 2021 ICPC Asia Shenyang Regional Contest
    The2021ICPCAsiaShenyangRegionalContest我们按难易程度来,E,F<B,J<H,I,L,ME.EdwardGaming,theChampion直接输出edgnb子字符串数量。F.EncodedStringsI分......
  • 2021-10-22日记
    哎,真是醉了,今天真的是明白一件事儿,越是想贪便宜就越是贪不了便宜。说是今天信用卡有活动,加油中石化五折,于是下班后兴冲冲跑过去了,结果被告知有时间限制,过了晚上五点就没有这......
  • 校园社团活动管理系统 2021级大二期中考试
       大体上和2019级的基本相同,可以说是换汤不换药个人写的比较拙劣,基本完成了题目要求,发出来供大家参考,如有需要也可参考19级的第七次人口普查的代码 话不多说上......
  • NOI2021模拟测试赛(六十)
    题面西克把\(x\toy\)拆成\(x\tolca\toy\),而\(x\tolca\)的部分很好搞,不予阐述。关键是\(y\tolca\)的部分,我们考虑离线解决。从上往下走时,对每种颜色\(c\)......
  • 2021 ICPC EC Final B. Beautiful String 题解
    2021ICPCECFinalB.BeautifulString题解题意问给定字符串t的所有子串中形如"114514"分割方案之和。其中'1'、'4'、'5'表示某一字符串,且可重复。分析(暴力\(n^3\))......
  • NOIP 2021 游记
    Day0对着大纲找了点很板子的题做,主要找的dcc和scc缩点、树形DP和DP优化、KMP之类的。睡前祈祷不要失眠,结果在即将睡着后外面传来钢琴声,直接失眠........emmmmmmm。Day1......
  • CSP-S 2021 游记
    Day0下午试机,打了一下板子,发现编译都过不了人都傻了,结果是32位机。于是就以为整个机房都是32位机,考试的时候发现自己的机子是64位的,运气真好。试了一下对拍器,看来库里的......