博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
計蒜客/小教官(xjb)
阅读量:5338 次
发布时间:2019-06-15

本文共 1302 字,大约阅读时间需要 4 分钟。

題目鏈接:

 

題意:中文題誒~

 

思路: 先通過給出的條件構造一個符合題意的數組(可以是任意一個符合條件的數組,菜雞不會證明;

然後構造的數組和初始序列1, 2, 3, 4...n最少不同元素的個數就是答案;

這點是比較好理解的:題目中給出的b1, b2, ...bm可以是不連續的, 那麼如果每次選擇的m個與初始序列不同位置的元素並且通過一次操作後可以到達初始序列所在位置;

那麼所需代價肯定是最小的,總代價即爲位置不同的元素的數目. 所有情況都可以分解爲m爲 2 或 3的情況的組合,而對於m爲2, 3的情況前面所述顯然是正確的;

那麼剩下的問題就是求目標序列和構造序列最少多少個元素不同了,注意這裏的序列是循環序列;

對於循環序列, 並不確定其開頭元素是那個,枚舉其開頭元素的話,時間復雜度爲O(n^2), 顯然會tle;事實上也並不需要那樣做,可以先求最多有多少個元素與初始序列位置相同;

再用n減一下即可. 注意這裏的初始序列是一個特殊的序列,爲1, 2, 3, 4...n, 那麼可以用(a[i]-i+n)%n表示其相對序列,相對序列號相同的元素一定存在某個開頭元素使其位置與

初始序列是相同的, 所以只要找出最多的相對序列號相同的元素數目即爲對多與初始序列位置相同的元素的個數;

注意還要逆時針再計算一邊相對序列號相同的最多元素數目;

 

代碼:

1 #include 
2 #include
3 #include
4 using namespace std; 5 6 const int MAXN=5e4+10; 7 int a[MAXN], vis[MAXN]; 8 struct node{ 9 int f, s;10 }gg[MAXN];11 12 int main(void){13 int n;14 scanf("%d", &n);15 for(int i=1; i<=n; i++){16 scanf("%d%d", &gg[i].f, &gg[i].s);17 }18 a[1]=1;19 vis[1]=true;20 int indx=1, cnt=1;21 while(1){
//構造序列22 int cc=gg[cnt].f;23 if(vis[cc]){24 cc=gg[cnt].s;25 if(vis[cc]) break;26 }27 vis[cc]=true;28 a[++indx]=cc;29 cnt=cc;30 }31 if(indx
View Code

 

转载于:https://www.cnblogs.com/geloutingyu/p/6791383.html

你可能感兴趣的文章
hdu 1207 四柱汉诺塔
查看>>
Vue 2.x + Webpack 3.x + Nodejs 多页面项目框架(上篇——纯前端多页面)
查看>>
display:none与visible:hidden的区别
查看>>
我的PHP学习之路
查看>>
【题解】luogu p2340 奶牛会展
查看>>
对PostgreSQL的 SPI_prepare 的理解。
查看>>
解决响应式布局下兼容性的问题
查看>>
京东静态网页练习记录
查看>>
使用DBCP连接池对连接进行管理
查看>>
【洛谷】【堆+模拟】P2278 操作系统
查看>>
hdu3307 欧拉函数
查看>>
Spring Bean InitializingBean和DisposableBean实例
查看>>
Solr4.8.0源码分析(5)之查询流程分析总述
查看>>
[Windows Server]安装系统显示“缺少计算机所需的介质驱动程序”解决方案
查看>>
[容斥][dp][快速幂] Jzoj P5862 孤独
查看>>
Lucene 学习之二:数值类型的索引和范围查询分析
查看>>
软件开发工作模型
查看>>
Java基础之字符串匹配大全
查看>>
面向对象
查看>>
lintcode83- Single Number II- midium
查看>>