首页 > 其他 > 详细

Codeforces Round #439 (Div. 2)

时间:2017-10-08 00:49:22      阅读:365      评论:0      收藏:0      [点我收藏+]

A题

分析:注意异或以后可能会大于2e6,所以数组应该开到4e6。还有一种巧妙的解法就是用异或的性质,b^a^b=a,所以可以看出必然都是偶数对。

技术分享
 1 #include "iostream"
 2 #include "cstdio"
 3 #include "cstring"
 4 #include "string"
 5 #include "cmath"
 6 #include "vector"
 7 using namespace std;
 8 const int maxn=5000;
 9 const int maxm=4e6+10;
10 int x[maxn],y[maxn];
11 int vis[maxm];
12 int n;
13 //vector<int> res;
14 int main()
15 {
16     scanf("%d",&n);
17     //res.push_back(0);
18     for(int i=1;i<=n;i++){
19         scanf("%d",&x[i]);
20         vis[x[i]]=1;
21         //res.push_back(x[i]);
22     }
23     for(int i=1;i<=n;i++){
24         scanf("%d",&y[i]);
25         vis[y[i]]=1;
26         //res.push_back(y[i]);
27     }
28     int cnt=0;
29     for(int i=1;i<=n;i++){
30         for(int j=1;j<=n;j++){
31             int num=x[i]^y[j];
32             if(vis[num]){
33                 cnt++;
34                 //cout<<res[i]<<" "<<res[j]<<endl;
35                 //cout<<num<<endl;
36             }
37         }
38     }
39     //cout<<(1^1)<<endl;
40     //cout<<cnt<<endl;
41     if(cnt%2==0)
42         cout<<"Karen"<<endl;
43     else
44         cout<<"Koyomi"<<endl;
45 }
View Code

B题

分析:要求最后一位数分为几种情况,如果两数之差超过10的,因为最后一位出现0,所以必然为0。如果两数相等,直接对10曲余,否则直接暴力即可。

技术分享
 1 #include "iostream"
 2 #include "cstdio"
 3 #include "cstring"
 4 #include "string"
 5 #include "vector"
 6 using namespace std;
 7 long long a,b;
 8 int main()
 9 {
10     cin>>a>>b;
11     if(b-a>=10){
12         cout<<"0"<<endl;
13     }else{
14         long long t=b-a;
15         if(t==0)
16             cout<<"1"<<endl;
17         else if(t==1){
18             cout<<b%10<<endl;
19         }
20         else{
21             long long z=1;
22             vector<int>t;
23             for(long long i=a+1;i<=b;i++){
24                 int num=i%10;
25                 t.push_back(num);
26             }
27             for(int i=0;i<t.size();i++)
28                 z*=t[i];
29             z=z%10;
30             cout<<z<<endl;
31         }
32     }
33 }
View Code

C题

分析:题意比较难理解,就是给定三个集合,每个集合的元素个数分别为a,b,c。然后相同的一个集合当中任何两元素之间最短路必须大于等于3。求最多有多少种连线方式。根据题意我们就可以得知,首先同色的不可能相连,同时两个同色的不能连在一个其他颜色上。这个结论太重要了,这就说明了我们连任意两种颜色是独立的,于是最后结果就是(a,b),(a,c),(b,c)三者的乘积。而对于选取任意两种颜色,假设(a<b),那我们如果选取k条线段的话,必然有C(a,k)*C(b,k)*k!种组合方式,所以最终结果也就是k从0取到a的和,然后其余颜色也依次类推。

技术分享
 1 #include "iostream"
 2 #include "cstdio"
 3 #include "cstring"
 4 #include "string"
 5 #include "cmath"
 6 #include "algorithm"
 7 using namespace std;
 8 typedef long long LL;
 9 const LL mod= 998244353;
10 const int maxn=5050;
11 LL a[10];
12 LL f[maxn],dp[maxn][maxn];
13 void init(int n){
14     f[0]=1;
15     for(int i=1;i<=n;i++){
16         f[i]=f[i-1]*i;
17         f[i]%=mod;
18     }
19     for(int i=0;i<=n;i++){
20         dp[i][0]=1;
21     }
22     for(int i=1;i<=n;i++){
23         for(int j=1;j<=i;j++){
24             dp[i][j]=(dp[i-1][j-1]%mod+(dp[i-1][j]%mod))%mod;
25         }
26     }
27 }
28 int main()
29 {
30     cin>>a[1]>>a[2]>>a[3];
31     sort(a+1,a+4);
32     init(5000);
33     LL num1=0,num2=0,num3=0;
34     for(int i=0;i<=a[1];i++){
35         num1+=((dp[a[1]][i]%mod*(dp[a[2]][i]%mod))%mod*f[i])%mod;
36         num1%=mod;
37     }
38     for(int i=0;i<=a[2];i++){
39         num2+=((dp[a[2]][i]%mod*(dp[a[3]][i]%mod))%mod*f[i])%mod;
40         num2%=mod;
41     }
42     for(int i=0;i<=a[1];i++){
43         num3+=((dp[a[1]][i]%mod*(dp[a[3]][i]%mod))%mod*f[i])%mod;
44         num3%=mod;
45     }
46     LL ans=((num1*num2)%mod*num3)%mod;
47     cout<<ans<<endl;
48 }
View Code

 

Codeforces Round #439 (Div. 2)

原文:http://www.cnblogs.com/wolf940509/p/7636291.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!