Codeforces Round #624 (Div. 3) B,C,D;

题链:http://codeforces.com/contest/1311

B WeirdSort

每次指针从头开始,如果当前这个数大于下一个数,说明需要更换,这是就要判断是否有这个更换条件,然后指针更新从头开始;思想就是暴力加技巧;

#include 
using namespace std;
map<int,int> mp;
int a[200];
int main()
{
	int t;
	cin >>t;
	while(t--)
	{
		mp.clear();
		int n,m,x;
		cin >>n>>m;
		for(int i=1;i<=n;i++) cin>>a[i];
		for(int i=0;i<m;i++) cin>>x,mp[x]++;
		int flag=1;
		for(int i=1;i<n;i++)
		{
			if(a[i]>a[i+1]&&mp[i]) swap(a[i],a[i+1]),i=0;
			else if(a[i]>a[i+1]&&!mp[i])
			{
				flag=0;
				break;
			}
		}
		if(flag) cout <<"YES"<<endl;
		else cout <<"NO"<<endl;
	}
}

.
.

C Perform the Combo

暴力的话不能用N^2暴力,而是要优化成N*26;二位数组存放每次操作后每个字符的个数,更新二位数组的方法是将上一次操作的值复制过来,然后加上这次的选择;

#include 
using namespace std;
int x[2*100005][50];
int p[2*100005];
int sum[30];
int main()
{
	//cout <<'a'-'a'<
	int t;
	cin >>t;
	while(t--)
	{
		memset(sum,0,sizeof sum);
		int n,m;
		cin >>n>>m;
		for(int i=0;i<=n;i++)
		{
			for(int j=0;j<26;j++) x[i][j]=0;
		}
		string s;
		cin >>s;
		for(int i=1;i<=m;i++) cin >>p[i]; 
		int len=s.size();
		int cnt=1;
		for(int i=0;i<len;i++)
		{
			for(int j='a'-'a';j<26;j++)
			{
				if(x[cnt-1][j]) x[cnt][j]=x[cnt-1][j];
			}
			x[cnt++][s[i]-'a']++;
		}
		for(int i=1;i<=m;i++)
		{
			int y=p[i];
			for(int j='a'-'a';j<26;j++)
			{
				sum[j]+=x[y][j];
			}
		}
//		for(int i='a'-'a';i<26;i++) cout <
//		cout <
		for(int i='a'-'a';i<26;i++)
		{
			sum[i]+=x[n][i];
		}
		for(int i='a'-'a';i<26;i++) cout <<sum[i]<<" ";
		cout <<endl;
	}
}

D :Three Integers

暴力枚举;需要注意的是,题中没有规定C的范围;但是C的最大值也就2E4;所以暴力枚举即可;还有k应该从开始;要不然会被hack;

#include 
using namespace std;
typedef long long ll;
const int N=20005;
int main()
{
	int  t;
	cin >>t;
	while(t--)
	{
		int a,b,c,A,B,C;
		cin >>a>>b>>c;
		int ans=0x3f3f3f3f;
		for(int i=1;i<=N;i++)
		{
			for(int j=i;j<=N;j+=i)
			{
				for(int k=0;k<=N;k+=j)
				{
					int res=abs(a-i)+abs(b-j)+abs(c-k);
					if(ans>res) ans=res,A=i,B=j,C=k;
				}
			}
		}
		cout <<ans<<endl;
		cout <<A<<" "<< B<<" "<<C<<endl;
	}
}

你可能感兴趣的:(基础算法——数论,思维)