Codeforces Round #580 (Div. 2)

A:

题意:给你 a,b俩个集合 求任意一个 a[i] + b[j]  不属于俩个集合。

思路:俩集合全部丢set 然后暴力枚举每个和。

AC代码:

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 int a[500], b[500];
 4 set<int> st;
 5 int main()
 6 {
 7     int n, m;
 8     cin >> n;
 9     for(int i = 0;i < n;i++)
10     {
11         cin >> a[i];
12         st.insert(a[i]);
13     }
14     cin >> m;
15     for(int i = 0;i < m;i++)
16     {
17         cin >> b[i];
18         st.insert(b[i]);
19     }
20     for(int i = 0;i < n;i++)
21         for(int j = 0;j < m;j++)
22         {
23             if(st.count(a[i] + b[j]) == 0)
24             {
25                 cout << a[i] << " " << b[j];
26                 return 0;
27             }
28         }
29     return 0;
30 }

B:

题意:让通过增减1的方式所有元素乘积等于1;

思路:贪心,正数直接到 1 ,负数到-1,如果最后乘积为 -1并且 0 的个数为0则答案加 2,否则答案 + 0的个数。

AC代码:

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 const int maxn = 1e5 +5;
 4 long long a;
 5 int main()
 6 {
 7     long long  sum = 1;
 8     long long ans = 0;
 9     long long zero = 0;
10     int n;
11     cin >> n;
12     for(int i = 0;i < n;i++)
13     {
14         cin >> a;
15         if(a > 0)
16         {
17             ans += abs(a - 1);
18             sum *= 1;
19         }
20         else
21         if(a == 0) zero ++;
22         else{
23             ans += abs( - 1 - a);
24             sum *= -1;
25         }
26     }
27     if(sum == 1) cout << ans + zero << endl;
28     else
29     {
30         if(zero) cout << ans + zero << endl;
31         else cout << ans + 2LL;
32     }
33     return 0;
34 }

C:

这题我不会,看着图解随便猜的,结果就过了,偶数为 NO ,奇数对称来回摆。

AC代码

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 const int maxn = 2e5 + 5;
 4 int a[maxn],b[maxn];
 5 int main()
 6 {
 7     int n;
 8     cin >> n;
 9     if(n%2 == 0) cout << "NO" << endl;
10     else {
11         cout << "YES" << endl;
12         int aa = 0;
13         int bb = 0;
14         int cnt = 0;
15         for(int i = 1;i <= 2*n;i++)
16         {
17             if(!cnt)
18             {
19                 a[aa++] = i++;
20                 b[bb++] = i;
21                 cnt = 1;
22             }
23             else
24             {
25                 b[bb++] = i++;
26                 a[aa++] = i;
27                 cnt = 0;
28             }
29         }
30         for(int i = 0;i < aa;i++) cout << a[i] << " ";
31         for(int i = 0;i < bb;i++) cout << b[i] << " ";
32     }
33     return 0;
34 }

D:

题意:n个点,如果 A[ i ] & A[ j ]  != 0 则认为 i 和 j 之间有路,问图的最小环是多少。

思路:将A[ i ]用二进制表示,可以发现当某一列的1超过3次,则最小环为3,再由鸽巢原理,超过3*64的 n 即可直接输出3退出,剩下的跑floyd最小环自己到自己即可。(赛时不知道鸽巢原理的我看着1e5*64的二进制图发呆orz)

AC代码:

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 typedef long long ll;
 4 const int maxn = 4e6 + 50;
 5 const int INF = 1e9;
 6 ll a[maxn];
 7 int num[80];
 8 ll mp[500][500];
 9 ll d[500][500];
10 void getnum(ll x)
11 {
12     for(int i = 63;i >= 0;i--)
13     {
14         if(x & (1LL << i)) num[i] ++;
15     }
16 }
17 int main()
18 {
19     std::ios::sync_with_stdio(false);
20     int n;
21     cin >> n;
22     for(int i = 1;i <= n;i++)
23     {
24         cin >> a[i];
25         if(a[i] == 0)
26         {
27             n--,i--;
28             continue;
29         }
30         getnum(a[i]);
31  
32     }
33     for(int i = 0;i < 80;i++)
34     {
35         if(num[i] >= 3)
36         {
37             cout << 3 << endl;
38             return 0;
39         }
40     }
41     for(int i = 1;i <= n;i++)
42         for(int j = 1;j <= n;j++)
43             mp[i][j] = INF,d[i][j] = INF;
44     for(int i = 1;i <= n;i++)
45         for(int j = i+1;j <= n;j++)
46             if(a[i]&a[j])
47             mp[i][j]=1,mp[j][i]=1,d[i][j]=1,d[j][i]=1;
48     ll ans = INF;
49     for(int k = 1;k <= n;k++){
50         for(int i = 1;i < k;i++){
51             for(int j = i+1;j < k;j++){
52                 ans = min(d[i][j] + mp[j][k] + mp[k][i],ans);
53             }
54         }
55         for(int i = 1;i <= n;i++){
56             for(int j = 1;j <= n;j++){
57                 if(d[i][j] > (d[i][k] + d[k][j])){
58                     d[i][j] = d[i][k] + d[k][j];
59                 }
60             }
61         }
62     }
63     if(ans == INF) cout << -1 << endl;
64     else cout << ans << endl;
65     return 0;
66 }

 

转载于:https://www.cnblogs.com/Carered/p/11387318.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值