Codeforces Round #411 (Div. 2)

A. Fake NP

 题意:给定区间,问区间里面出现次数最多的因子。

 思路:除了l=r并且l是质数,其他情况都是2.

#include<bits/stdc++.h>
using namespace std;
int main(){
	ios::sync_with_stdio(false);
	int l,r;
	cin>>l>>r;
	if(l==r)
		cout<<l<<"\n";
	else 
	puts("2");
}

 B. 3-palindrome

题意:只能用a,b,c三种字符构造,保证c字符数量最少并且不含长度为3的回文子串。

 思路:不出现长度为3的回文子串那么aabbaabb....不就满足条件了吗

#include<bits/stdc++.h>
using namespace std;
int main(){
	ios::sync_with_stdio(false);
	int n;
	cin>>n;
	string s="aabb";
	if(n<=4){
		for(int i=0;i<n;i++)
			cout<<s[i];
	}
	else{
		int t=n/4;
		for(int i=0;i<t;i++)
			cout<<s;
		int t1=n-4*t;
		for(int i=0;i<t1;i++)
			cout<<s[i];
	}	
}

 C. Find Amir

题意:给定n,对于(i,j)如果想从i去j或从j去i,只要花费1次(i+j)%(n+1),问能去所有点的最少花费。

思路:对于n=5,1,2,3,4,5,(1+5)=6,(2+4)=6这些点不需要钱,还有3,2,5,没连接,可以看出2+5=7,3+4=7,那么只要花费1元钱就可以了所以总花费为(n-2)/2+1.注意n=1时。

#include<bits/stdc++.h>
using namespace std;
int main(){
	ios::sync_with_stdio(false);
	int n;
	cin>>n;
	if(n==1)
		puts("0");
	else if(n%2){
		printf("%d\n",(n-2)/2+1);
	}
	else printf("%d\n",(n-2)/2);
}

 D. Minimum number of steps

题意:对于‘ab’将它换成'bba'问总共可以操作多少次。

 思路:可以看出最终结果会变成bbb...aaa...的结果,前面的结果对后面没影响,可以看出规律,前面b有多少个a就操作2^n-1次。

 

#include<bits/stdc++.h>
using namespace std;
const int mod=1e9+7;
typedef long long ll;
ll ksm(ll x,ll y){
	ll res=1;
	while(y){
		if(y&1)
			res=res*x%mod;
		x=x*x%mod;
		y/=2;
	}
	return res;
}
int main(){
	ios::sync_with_stdio(false);
	string s;
	cin>>s;
	ll cnt=0;
	ll ans=0;
	for(int i=0;i<s.size();i++){
		if(s[i]=='a')
			cnt++;
		else ans=(ans+ksm(2,cnt)-1)%mod;	
	}
	printf("%lld\n",ans);
}

E. Ice cream coloring

题意:有一颗树 有n个结点和n-1条边,每个结点有s个冰淇淋,同一个结点的冰淇淋相邻。 现在要给这些冰淇淋染色,相邻的不能同色,问最少要多少个颜色,怎么染。 题目还给出一个条件,相同冰淇淋的结点在一个连通块中

 思路:dfs染色加贪心

#include<bits/stdc++.h>
using namespace std;
vector<int>v1[350000],v2[350000];
map<int,int>q;
int col[350000];
void dfs(int now,int pre){
	q.clear();
	for(int i=0;i<v1[now].size();i++){
		if(col[v1[now][i]])
			q[col[v1[now][i]]]=1;
	}
	int t=0;
	for(int i=0;i<v1[now].size();i++){
		if(col[v1[now][i]])
			continue;
		while(q[++t]);
		col[v1[now][i]]=t;
	}
	for(int i=0;i<v2[now].size();i++){
		if(v2[now][i]!=pre)
			dfs(v2[now][i],now);
	}
}
int main(){
	int n,m,ans=0;
	scanf("%d%d",&n,&m);
	if(m)
		ans=1;
	memset(col,0,sizeof(col));
	for(int i=1;i<=n;i++){
		int x;
		scanf("%d",&x);
		ans=max(ans,x);
		for(int j=0;j<x;j++){
			int a;
			scanf("%d",&a);
			v1[i].push_back(a);
		}
	}
	for(int i=1;i<n;i++){
		int u,v;
		scanf("%d%d",&u,&v);
		v2[u].push_back(v);
		v2[v].push_back(u);
	}
	dfs(1,-1);
	printf("%d\n",ans);
	for(int i=1;i<=m;i++){
		if(col[i]!=0)
			printf("%d ",col[i]);
		else printf("1 ");
	}
	printf("\n");
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值