当前位置: 首页 > news >正文

D. Constant Palindrome Sum(差分数组维护)

Problem - D - Codeforces

题意:给定长度为n的数组,每次操作可以选择一个数令a[i]变成[1,k]范围内的一个数,问最少需要多少次操作可以让a[i]+a[n-i+1]==x (1<= i <= n/2)满足。

思路:利用差分数组d[i]表示x取i需要的总操作数。

枚举每一对数,计算x的取值范围及所需的操作数

记mi=min(a[i] , a[n-i+1])

ma=max(a[i] , a[n-i+1])

sum=a[i] + a[n-i+1]

修改一个数时,x取值范围为[mi+1, ma+k];修改两个数时,x的取值范围为[2,2k]

所以当x∈[mi+1, ma+k],为达到x需要修改一次,即让[mi+1, ma+k]范围内的数都+1

当x∈[2,mi+1)∪(ma+k, 2k],为达到x需要修改两次,即让[2,mi+1)∪(ma+k, 2k]范围内的数都+2

注意当x==sum时,不要操作

#include <bits/stdc++.h>
#define lowbit(x) x&(-x)
#define ios cin.sync_with_stdio(false)
#define PII pair<int,int>
typedef long long ll;
const int N=1e6+10;
const int inf=0x3f3f3f3f;using namespace std;
int n,k;
int a[N],d[N];
void solve()
{cin>>n>>k;for(int i=1;i<=n;i++) cin>>a[i];for(int i=0;i<=2*k;i++) d[i]=0;for(int i=1;i<=n/2;i++){int mi=min(a[i],a[n-i+1]);int ma=max(a[i],a[n-i+1]);int sum=a[i]+a[n-i+1];d[2]+=2;d[mi+1]--;d[sum]--;d[sum+1]++;d[ma+k+1]++;d[2*k+1]--;}for(int i=1;i<=2*k;i++)d[i]+=d[i-1];int ans=inf;for(int i=2;i<=2*k;i++)ans=min(ans,d[i]);cout<<ans<<'\n';
}
signed main()
{//ios;int _t=1;cin>>_t;while(_t--) solve();system("pause");return 0;
}

http://www.lryc.cn/news/31929.html

相关文章:

  • 【C++】30h速成C++从入门到精通(IO流)
  • 文件变成chk如何恢复正常
  • Meta最新模型LLaMA细节与代码详解
  • 3/6考试总结
  • 产品经理必读书单
  • UEFI移植LVGL
  • RK356x U-Boot研究所(命令篇)3.8 test命令的用法
  • LCD液晶段码驱动IC/LCD液晶驱动芯片VK2C22高抗干扰/抗噪,适用于汽车仪表/单相智能电表
  • OpenMMLab 目标检测
  • Jenkins部署angular11自动打包
  • 【状态管理】zustand 中文文档,它来了!!!
  • 【时序】特征工程-时间序列特征构造
  • 【独家】华为OD机试 - 环中最长子串(C 语言解题)
  • JavaScript新手学习手册-基础代码(一)
  • Firewall App Blocker v1.7 防火墙管理设置工具多语言版
  • windows常用
  • 从源码的角度告诉你 spark是怎样完成对文件切片
  • 剑指 Offer II 019. 最多删除一个字符得到回文
  • RK3568驱动OV13850摄像头模组调试过程
  • Go项目的目录结构基本布局
  • CHAPTER 1 Linux Filesystem Management
  • RocketMQ架构篇 - 读写队列与生产者如何选择队列
  • 华为OD机试真题Python实现【通信误码】真题+解题思路+代码(20222023)
  • 【单目3D目标检测】MonoDDE论文精读与代码解析
  • 复习 Kotlin 从小白到大牛 第二版 笔记要点
  • X264简介-Android使用(二)
  • 【独家】华为OD机试 - 统计差异值大于相似值二元组个数(C 语言解题)
  • 掌握好Framework 才是王道~
  • Codeforces Round 856 (Div. 2) A — C
  • 2022年MathorCup数学建模B题无人仓的搬运机器人调度问题解题全过程文档加程序