码迷,mamicode.com
首页 > 其他好文 > 详细

[SRM] 17

时间:2017-09-03 14:10:50      阅读:160      评论:0      收藏:0      [点我收藏+]

标签:iostream   names   efi   交换   位置   接下来   构造   子节点   click   

qwq 怎么就17了

 

A.

对于待操作数列,所有的两个操作在宏观似乎都不会改变大体顺序

(至于操作2交换奇偶位数字:奇偶分离就行了)

那么定义 s1 s2 分别为奇数列和偶数列的起点(奇数和偶数自己是不会改变相对位置的)

让 s1 s2 储存每次操作一的偏移量

最后构造数列

技术分享
 1 #include<cstdio>
 2 #include<iostream>
 3 #define maxn 1000000
 4 using namespace std;
 5 
 6 int ans[maxn],s1,s2,n,m,cnt,cnt2;
 7 
 8 int main(){
 9     scanf("%d%d",&n,&m);
10     
11     s1 = 1,s2 = 2;
12     
13     for(int i = 1;i <= m;i++){
14         scanf("%d",&cnt);
15         
16         if(cnt%2){
17             scanf("%d",&cnt2);
18             s1 += cnt2;
19             s2 += cnt2;
20             if(s1 <= 0) s1 += n;
21             if(s1 > n) s1 -= n;
22             if(s2 <= 0) s2 += n;
23             if(s2 > n) s2 -= n;
24         }else{
25             if(s1 % 2) s1++;
26             else s1--;
27             if(s2 % 2) s2++;
28             else s2--;
29         }
30     }
31     
32     int i = s1,cnt = 1;
33     while(!(i == s1 && cnt != 1)){
34         ans[i] = cnt;
35         i += 2;
36         cnt += 2;
37         if(i > n) i -= n;
38     }
39     
40     i = s2,cnt = 2;
41     while(!(i == s2 && cnt != 2)){
42         ans[i] = cnt;
43         i += 2;
44         cnt += 2;
45         if(i > n) i -= n;
46     }
47     
48     for(int i = 1;i <= n;i++){
49         printf("%d ",ans[i]);
50     }
51     
52     return 0;
53 } 
A

 

C.

只限定了树的直径和树的高

那就简单了,最低限度满足条件即可

首先画一条长度为D的多段线,那么一个典型的情况是:树根 1 在中点,将该多段线打折则每边的长度为 D/2

这是临界点,此时树高为 H

那么我们就知道了:如果 H * 2 < D 则必然无解(怎么打折都会有一边超过预测 H )

那么我们只要在多段线上取一个点定为 1 就行了,接下来就是处理多余的结点(D+1 ~ n )

(解释起来真复杂) 

最简单的方法就是把多余节点一个个挂在深度第二的点当子节点

(有那么点画同分异构体的感觉)

既然这题的限制如此之少,又没有什么保证 既然这题出自CF

就要往死里加特判,不要太相信自己程序的通用度

特判见代码

技术分享
 1 #include<cstdio>
 2 #include<iostream>
 3 using namespace std;
 4 
 5 int n,D,H,pre[1000000];
 6 
 7 int main(){
 8     scanf("%d%d%d",&n,&D,&H);
 9     
10     if(H*2 < D || H > D || D == 1 || n-1 < D || n-1 < H) cout << -1;
11     else{
12         if(H < D){
13             
14             for(int i = 2;i <= H+1;i++){
15                 pre[i] = i-1;
16             }
17             
18             pre[H+2] = 1;
19             for(int i = H+3;i <= D+1;i++){
20                 pre[i] = i-1;
21             }
22             
23             for(int i = 2;i <= n;i++){
24                 if(!pre[i]) pre[i] = H;
25             }
26             
27         }else{
28             
29             for(int i = 2;i <= H+1;i++){
30                 pre[i] = i-1;
31             }
32             
33             for(int i = 2;i <= n;i++){
34                 if(!pre[i]) pre[i] = H;
35             }
36             
37         }
38         for(int i = 2;i <= n;i++)
39         printf("%d %d\n",pre[i],i);
40     }
41     
42     
43     
44     return 0;
45 } 
重构代码把D == 1给忘了然后就FST了qwq

 

[SRM] 17

标签:iostream   names   efi   交换   位置   接下来   构造   子节点   click   

原文地址:http://www.cnblogs.com/Chorolop/p/7469409.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!