CodeForces 669D Little Artem and Dance
来源:互联网 发布:淘宝宝贝背景图片素材 编辑:程序博客网 时间:2024/04/28 04:07
【题意】给你n个数,一开始是1 2 3 4 5 6 这样的,现在有两个操作,第一个操作是所有数向右边移动x个位置,第二个操作奇数和偶数的位置互换
思路:比较显然就是,奇数和偶数位置的数的相对位置是不会变的,那么我们只要知道1和2这两个位置的数是啥就好了
然后交换的时候,我们就模拟一下这两个位置的交换就好了
【AC代码】
#include <bits/stdc++.h>using namespace std;int n,q,x;int main(){ int a=0,b=0; scanf("%d%d",&n,&q); while(q--){ int tmp; scanf("%d",&tmp); if(tmp==1){ scanf("%d",&x); a = (n+a-x)%n; b = (n+b-x)%n; if(x%2) swap(a,b); //当x为奇数时,1,2的位置奇偶性必然改变成相反的 }else{ a = (a+n-1)%n; b = (b+n+1)%n; swap(a,b);//交换奇偶位置 } } for(int i=1; i<=n; i++){ if(i%2) printf("%d ",(a+i-1+n)%n+1);//用1的位置递推所有奇数位置的编号 else printf("%d ",(b+i-1+n)%n+1); //用2的位置递推所有偶数位置的编号 } return 0;}
1 0
- CodeForces 669D Little Artem and Dance
- CodeForces 669D Little Artem and Dance
- Codeforces #669 Div2. D. Little Artem and Dance(思维)
- Codeforces 669D Little Artem and Dance (脑洞)
- CodeForces 669D Little Artem and Dance(思维)
- codeforces#348-D - Little Artem and Dance-规律-模拟
- Codeforces 669D Little Artem and Dance【思维】好题!好题!
- CodeForces 668B Little Artem and Dance
- Codeforces Round #348 (VK Cup 2016 Round 2, Div. 2 Edition) D. Little Artem and Dance
- CodeForces 641C Little Artem and Dance (模拟)
- CodeForces 641 C.Little Artem and Dance(水~)
- Codeforces Round 669D Little Artem and Time Machine
- Little Artem and Dance(思路)
- CodeForces 669A Little Artem and Presents
- CodeForces 669B Little Artem and Grasshopper
- CodeForces 669A Little Artem and Presents
- 【CodeForces】669A - Little Artem and Presents
- 【CodeForces】[669A]Little Artem and Presents
- 【bzoj1040】[ZJOI2008]骑士 基环+外向树dp
- AngularJS(一)——初识AngularJS
- JAVA中的集合的概念
- HTTP的简单理解
- 常见的HTTP 状态代码及其原因
- CodeForces 669D Little Artem and Dance
- 五一游,清华,北大
- JAVA语言之计数排序
- Geekband009第九周笔记分享
- 动态删除ArrayList中的元素
- 找到满足条件的数组
- Javascript事件全解析——事件概述及传统事件类型
- 读取Kafka集群的消息
- php环境搭建