CF1095D Circular Dance 题解
Circular Dance
题目大意
现在有一个有
思路
既然是个环,那么开头是几都可以,不妨设开头是一。
那么第二、第三个数必然只有两种选择。
设第二个数为
设第二个数为
前三数都推导好了,后面的数就轻松了。
给个公式:
可以自己推一推。
代码
点击查看代码
#include <iostream> using namespace std; const int N = 200010; int a[N][2]; int p[N]; int n, t; int main(){ cin >> n; for (int i = 1; i <= n; i++){ cin >> a[i][0] >> a[i][1]; // 读入不说话 } p[1] = 1; // 设第一个数为1 p[2] = a[1][0]; p[3] = a[1][1]; if(p[3] != a[p[2]][0] && p[3] != a[p[2]][1]){ // 先处理好第二第三个数 swap(p[2], p[3]); } for (int i = 4; i <= n; i++){ p[i] = a[p[i - 2]][0] + a[p[i - 2]][1] - p[i - 1]; // 公式 } for (int i = 1; i <= n; i++){ cout << p[i] << ' '; } return 0; // 完美结束 }
本文作者:wnsyou の blog
本文链接:https://www.cnblogs.com/wnsyou-blog/p/17410164.html
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步