传送门

怎么说呢,想了几个小时没做出来实在可惜。

\(\color{Red}{首先肯定想到暴力嘛!但是x定值有那么多值可以取,怎么办呢?}\)

但是题目中有一个很关键的条件

\[a[i]>=1\&\&a[i]<=k
\]

所以,在最坏情况下我们的答案会是\(n/2-s.(s为\frac{n}{2}对数中和为k+1的总数)\)

\(\color{Purple}{为什么?因为不管怎样,对于所有的\frac{n}{2}对数,我都可以改变一个数使得定值变成K+1.}\)

\[若改变一个值使得和最小,必定把最大值改为1,此时和为L=min(a,b)+1
\]

\[若改变一个值使得和最大,必定把最小值改为k,此时和为R=max(a,b)+k
\]

\(显然怎么取极值都可以改变一个数到达k+1.\)

\(还想缩小答案怎么办?那么定值只有\frac{n}{2}种选法,也就是把已有的和当作定值。\)

如果不是这样,每对数至少要改变一次,还不如上面的决策优秀。

\(这样一来,我们可以打出一个暴力代码。期望复杂度O(n^2)\)

暴力代码

但是上面说了那么一大堆,其实代码根本过不了哈哈(折磨一下你),卡死在了最后一个数据点。

\(\color{Orange}{--------------------(●ˇ∀ˇ●)我是一条分割线--------------------------}\)

那怎么另辟蹊径呢?其实做法和上面也没差太多。

\(注意到,定值可能取[2,2*k](当然根据上面的暴力分析可以缩小范围,不过没必要)\)

而且,对于任意的一组\(a[i],a[n-i+1]\)来说无非三种情况。

\(Ⅰ.改变一个数达到定值\)

\(Ⅱ.改变两个数达到定值\)

\(Ⅲ.不需要改变达到定值\)

\(现在令sumn=a[i]+a[n-i+1],x为定值,L,R(L和R的含义上面有分析)\)

\(\color{Red}{对于第一种情况,当x>=L\&\&x<=R\&\&x!=sumn时,所有满足条件的x操作数加1}\)

\(\color{Purple}{对于第二种情况,当x<L\|\| x>R时,所有满足条件的x操作数加2}\)

\(\color{Pink}{对于第三种情况,当x==sumn时满足,操作数不变}\)

那么我们完全可以维护每个数作为定制的操作数。

\(上面这些不都是区间加法吗?树状数组?线段树?差分?随便你辣!!\)

#include <bits/stdc++.h>
using namespace std;
const int maxn=4*1e5+9;
int t,n,k,a[maxn],vis[maxn];
int main()
{
cin>>t;
while(t--)
{
memset(vis,0,sizeof(vis));
cin>>n>>k;
for(int i=1;i<=n;i++) cin>>a[i];
for(int i=1;i<=n/2;i++)
{
int l = min(a[i] , a[n-i+1])+1;
int r = max(a[i] , a[n-i+1])+k;
int sumn = a[i] + a[n-i+1];
vis[2]+=2,vis[l]-=2;//no.1
vis[l]+=1,vis[r+1]-=1;//no.2
vis[r+1]+=2,vis[2*k+1]-=2;//no.3
vis[sumn]--,vis[sumn+1]++;//sumn在前面no.2多加了,减回来
}
int ans=1e9;
for(int i=2;i<=2*k;i++)
{
vis[i]+=vis[i-1];
ans=min(ans,vis[i]);
}
cout<<ans<<endl;
}
}

Constant Palindrome Sum(贪心*RMQ)的更多相关文章

  1. Codeforces Round #636div3 D. Constant Palindrome Sum (划分区间,差分)

    题意:给你一个长度为偶数n的数组,每次可以将一个元素修改为不大于k的值,要求每个a[i]+a[n-i+1]都相等,求最少操作多少次 题解:假设每一对的和都为sum,小的记为mn,大的记为mx;     ...

  2. Codeforces 486C Palindrome Transformation(贪心)

    题目链接:Codeforces 486C Palindrome Transformation 题目大意:给定一个字符串,长度N.指针位置P,问说最少花多少步将字符串变成回文串. 解题思路:事实上仅仅要 ...

  3. codeforces 486C Palindrome Transformation 贪心求构造回文

    点击打开链接 C. Palindrome Transformation time limit per test 1 second memory limit per test 256 megabytes ...

  4. SPOJ:Elegant Permuted Sum(贪心)

    Special Thanks: Jane Alam Jan*At moment in University of Texas at San Antonio - USA You will be give ...

  5. Codeforces Round #277 (Div. 2)C.Palindrome Transformation 贪心

    C. Palindrome Transformation     Nam is playing with a string on his computer. The string consists o ...

  6. Codeforces Round 486C - Palindrome Transformation 贪心

    C. Palindrome Transformation time limit per test 1 second memory limit per test 256 megabytes input ...

  7. URAL 1297 Palindrome (后缀数组+RMQ)

    题意:给定一个字符串,求一个最长的回回文子串,多解输出第一个. 析:把字符串翻转然后放到后面去,中间用另一个字符隔开,然后枚举每一个回文串的的位置,对第 i 个位置,那么对应着第二个串的最长公共前缀, ...

  8. A Magic Lamp HDU - 3183 (逆向贪心/RMQ)

    Kiki likes traveling. One day she finds a magic lamp, unfortunately the genie in the lamp is not so ...

  9. #333 Div2 Problem B Approximating a Constant Range (尺取 && RMQ || 尺取 && multiset)

    题目链接:http://codeforces.com/contest/602/problem/B 题意 :给出一个含有 n 个数的区间,要求找出一个最大的连续子区间使得这个子区间的最大值和最小值的差值 ...

随机推荐

  1. hibernate.current_session_context_class 比较权威的解释

    hibernate.current_session_context_class 博客分类: hibernate HibernateSpring多线程配置管理thread  遇到过的问题: 情景1: 在 ...

  2. 类 文件 右下角呈现 红色小圆圈,里面有一个J 标记

    intellj(idea) 项目中类 文件 右下角呈现 红色小圆圈,里面有一个J 标记,表明此为 未设置为源文件,没有编译,本来应该是属于源文件的,结果现在没有被标记为源文件,也就没法编译了.

  3. JAVA开发中相对路径,绝对路径全面总结

    JAVA开发中相对路径,绝对路径全面总结 博客分类: Java综合 JavaJSP应用服务器Servlet网络应用 1.基本概念的理解 绝对路径:绝对路径就是你的主页上的文件或目录在硬盘上真正的路径, ...

  4. break与continue对比

    - break 用来终止循环 - continue 用来跳出当前循环,继续下次循环 // 求1到100之间所有不能被3整除的整数的第一个大于2000的和 var sum = 0; for(var i= ...

  5. Java成长记录第二集--基础重点

    第一篇写的博客给自己的学习路线立了个flag后,感觉现在学习的积极性大增,这也离不开那几位老铁们的互相鼓励.废话不多说,现在给出自己总结的Java基础部分所要重点注意的内容,对以后的开发工作也是很常用 ...

  6. FormCloseQuery

    FormCloseQuery是一个事件回调函数,Close是一个功能函数.而FormCloseQuery与窗口的close有什么不同,通过跟踪Call stack发生在调用Close()函数关闭窗口时 ...

  7. ASE project demo:pdf

    欢迎使用 pdf ~ 主页面如下,整个app风格一致,保持简约舒适的视觉体验~ 侧边栏打开,可选择打开新的pdf文件,返回主页面,打开本地生词本,登录等操作~ 可以点击侧边栏OpenFile打开新的p ...

  8. jdk动态代理:由浅入深理解mybatis底层

    什么是代理 代理模式,目的就是为其他对象提供一个代理以控制对某个对象的访问,代理类为被代理者处理过滤消息,说白了就是对被代理者的方法进行增强. 看到这里,有没有感觉很熟悉?AOP,我们熟知的面向切面编 ...

  9. Linux学习笔记(二)文件操作命令

    文件操作命令 touch stat cat more less head tail ln touch 英文原意: change file timestamps 功能: 修改文件的时间戳 语法: tou ...

  10. java 一维数组的总结笔记

    数组 1. 一位数组的声明方式 type[] array Name 或 type arrayName[];(推荐使用第二种) 错误的声明方式 //int[5] intErrorArray;错误的 // ...