[CF819B]Mister B and PR Shifts
题意:定义一个排列$p_{1\cdots n}$的“偏移量”$D=\sum _{i=1}^n\left|p_i-i\right|$
求它所有的轮换排列中偏移量最小的是多少,要求输出轮换序数
暴力就是求出每个轮换排列然后计算$D$,我们不妨换个视角,看看如何计算每个$p_k$对不同排列的$D$的贡献
设$d_i$是轮换序数为$i$的轮换排列的偏移量(轮换从右往左),当前处理到$p_k$
#1若$p_k\geq k$
对$0\leq i\leq k-1$,贡献为$p_k-k+i$
对$k\leq i\leq k+n-p_k$,贡献为$n+k-p_k-i$
对$k+n-p_k+1\leq i\leq n-1$,贡献为$p_k-n-k+i$
#2若$p_k\lt k$
对$0\leq i\leq k-p_k-1$,贡献为$k-p_k-i$
对$k-p_k\leq i\leq k-1$,贡献为$p_k-k+i$
对$k\leq i\leq n-1$,贡献为$n+k-p_k-i$
区间加和,还带关于$i$的线性的项,直接打两个标记(常数,$i$的系数),最后扫一遍即可
- #include<stdio.h>
- #define ll long long
- int p[2000010];
- ll dc[4000010],dx[4000010];
- ll min(ll a,ll b){return a<b?a:b;}
- int main(){
- int n,i,pos;
- ll del,cnt,ans;
- scanf("%d",&n);
- for(i=1;i<=n;i++)scanf("%d",p+i);
- for(i=1;i<=n;i++){
- if(p[i]>=i){
- dc[0]+=(p[i]-i);
- dc[i]-=(p[i]-i);
- dx[0]++;
- dx[i]--;
- dc[i]+=(n+i-p[i]);
- dc[i+n-p[i]+1]-=(n+i-p[i]);
- dx[i]--;
- dx[i+n-p[i]+1]++;
- if(i+n-p[i]+1<=n-1){
- dc[i+n-p[i]+1]+=(p[i]-n-i);
- dx[i+n-p[i]+1]++;
- }
- }else{
- dc[0]+=(i-p[i]);
- dc[i-p[i]]-=(i-p[i]);
- dx[0]--;
- dx[i-p[i]]++;
- dc[i-p[i]]+=(p[i]-i);
- dc[i]-=(p[i]-i);
- dx[i-p[i]]++;
- dx[i]--;
- if(i<=n-1){
- dc[i]+=(n+i-p[i]);
- dx[i]--;
- }
- }
- }
- del=cnt=0;
- ans=9223372036854775807ll;
- for(i=0;i<n;i++){
- del+=dx[i];
- cnt+=dc[i];
- if(cnt+i*del<ans){
- ans=cnt+i*del;
- pos=i;
- }
- }
- printf("%I64d ",ans);
- if(pos==0)
- putchar('0');
- else
- printf("%d",n-pos);
- }
[CF819B]Mister B and PR Shifts的更多相关文章
- CF819B Mister B and PR Shifts 题解
题目 Some time ago Mister B detected a strange signal from the space, which he started to study. After ...
- CF819B Mister B and PR Shifts 思维题
分析 这道题\(n\leq10^{6}\),显然\(n^{2}\)的暴力是无法解决问题的 那么我们可以考虑数列的某一种性质 因为最终的答案是\(\sum{n \atop i=1} |p_i - i|\ ...
- Codeforces Round #421 (Div. 2) D. Mister B and PR Shifts
Codeforces Round #421 (Div. 2) D. Mister B and PR Shifts 题意:给一个长度为\(n\)的排列,每次可以向右循环移位一次,计算\(\sum_{i= ...
- D. Mister B and PR Shifts
;//开两倍空间 int n; arr p,cnt; int l,r,m; ll sum = ,ans; int main() { // file("test"); sdf(n); ...
- Codeforces Round #421 (Div. 2)D - Mister B and PR Shifts(模拟)
传送门 题意 给出n个数,计算在进行n-1次右移中\(min\sum_{i=1}^nabs(p_i-i)\) 分析 我们设置cnt[p[i]-i]为一个数p[i]与它标准位置(如1的标准位置为1)的左 ...
- codeforces 820 D. Mister B and PR Shifts(思维)
题目链接:http://codeforces.com/contest/820/problem/D 题意:求.有一种操作 k = 0: shift p1, p2, ... pn, k = 1: shif ...
- codeforces 819B - Mister B and PR Shifts(思维)
原题链接:http://codeforces.com/problemset/problem/819/B 题意:把一个数列整体往右移k位(大于n位置的数移动到数列前端,循环滚动),定义该数列的“偏差值” ...
- CF820D Mister B and PR Shifts
题目链接:http://codeforces.com/problemset/problem/820/D 题目大意: 给出一个\(n\)元素数组\(p[]\),定义数组\(p[]\)的误差值为\(\su ...
- Mister B and PR Shifts,题解
题目链接 分析: 题意很明白,不再多说了,直接分析题目,首先想一想暴力,直接枚举起点,然后求出来,时间复杂度n*n,显然不太好,所以我们考虑换一种方法枚举,当然本质还是枚举,其实你会发现变化i次和i+ ...
随机推荐
- sqlplus 几个命令:
sqlplus 几个命令: 在sys,system,sysman,scott四个用户权限中,scott用户最低. 其权限依次从高到低. cmd进入sqlplus sqlplus 登录命令: 登录sys ...
- TSP问题之状压dp法
首先,我们先来认识一下什么叫做TSP问题 旅行商问题,即TSP问题(Traveling Salesman Problem)又译为旅行推销员问题.货郎担问题,是数学领域中著名问题之一.假设有一个旅行商人 ...
- 异常message:There is no database named cloudera_manager_metastore_canary_test_db_hive_hivemetastore
NoSuchObjectException(message:There is no database named cloudera_manager_metastore_canary_test_db_h ...
- (转)详解HTML网页源码的charset格式
关于HTML网页源码的字符编码(charset)格式(GB2312,GBK,UTF-8,ISO8859-1等)的解释 crifan http://www.crifan.com/summary_expl ...
- Spring学习--引用其他Bean , 内部Bean
引用其他Bean: 组成应用程序的 Bean 经常需要相互协作以完成应用程序的功能 , 要使 Bean 能够相互访问, 就必须在 Bean 配置文件中指定对 Bean 的引用. 在 Bean 的配置文 ...
- 51Nod 1421
1421 最大MOD值 有一个a数组,里面有n个整数.现在要从中找到两个数字(可以是同一个) ai,aj ,使得 ai mod aj 最大并且 ai ≥ aj. Input 单组测试数据. 第一行包含 ...
- BZOJ 2095: [Poi2010]Bridges
2095: [Poi2010]Bridges Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 869 Solved: 299[Submit][Stat ...
- 【STSRM13】花六游鸟小
[题意]给定n个节点的树,每个节点有一个m位二进制数,数字可以随时按位取反,每个数位有一个价值,定义每个点的最大价值是从根到这个点路上的数字(可以取反)或起来的数字中,1有价值0无价值,加起来得到的最 ...
- poj 2406 Power Strings(kmp循环节)
题目链接:http://poj.org/problem?id=2406 题目大意:如果n%(n-next[n])==0,则存在重复连续子串,长度为n-next[n]. 例如: a b ...
- Splunk Power User认证
课程介绍 | 通过 Splunk Fundamentals Part 1 课程考试 | 获取splunk certificate user 证书 | 课程为14节课+课后实验环境+课后习题 | 课程有 ...