2017acm南宁现场赛 J题 Rearrangement

题意:

给定一个2 * n的矩阵, 和 2 * n 个数, 问能不能通过重排列, 使得任意相邻两数不能被3整除

分析:

这题一直卡到最后, 赛后经对面大佬提醒后, 发现统计所有数模三的结果(0,1,2三种), 然后考虑怎么去“构造”符合这样的矩阵就行。

本地只过了用例和一些小数据, 等一个重现赛。

 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 const int maxn = 10000 + 7;
 4 int n;
 5 int num[maxn*2];
 6 int _0,_1,_2;
 7 bool judge()
 8 {
 9      if(_0 > n)//_0会有相邻
10         return false;
11 
12      if(_1 == 0 || _2 == 0) // 只有1, 2其中一种, 不用分割
13         return true;
14 
15      if(_0 <= 1)//有1, 2两种而且不形成分割
16         return false;
17 
18      if(_0 == n)
19         return true;
20      if(_0 % 2 == 0)
21     /* _0偶数情况, 形成|* 2 2 2|
22                       |1 * 2 2|可以隔出奇数个位置   */
23      {
24         if(_1 % 2 == 0 || _2 % 2 == 0)//偶数个位置不能被隔开
25             return false;
26 
27         return true;
28      }
29      else
30      /* _0奇数情况, 形成|* & * 2|
31                        |1 * 2 2|至少有(_0 - 2)个围住位置(&)可以任选, 所以奇偶都行*/
32      {
33 
34         return true;
35      }
36 }
37 int main()
38 {
39 //    freopen("data.txt","r", stdin);
40     int T;
41     scanf("%d", &T);
42     while(T--)
43     {
44         scanf("%d", &n);
45         _0 = _1 = _2 = 0;
46         for(int i = 0; i < 2*n; i++)
47         {
48             scanf("%d", &num[i]);
49             if(num[i] % 3 == 0) _0++;
50             else if(num[i] % 3 == 1) _1++;
51             else _2++;
52         }
53 //        printf("%d %d %d\n", _0, _1, _2);
54         printf("%s\n", judge()? "YES":"NO");
55     }
56     return 0;
57 }

 

转载于:https://www.cnblogs.com/Jadon97/p/7901128.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值