ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

CF883I Photo Processing (二分,单调队列优化DP)

2022-06-22 12:34:14  阅读:130  来源: 互联网

标签:const int Photo Processing mid long hh DP define


题意: 有一个n个数的集合,要分成若干子集,每个子集至少有m个数,每个子集的权值为最大数减最小数,求最小的最大权
思路: 先把数组排序。二分转化为判定性问题,check时候不能简单的贪心,设dp数组f[i]表示第i个数作为一个集合结尾是否可行 f[i] |= f[j] | l <= j <= r, 其中l是满足a[i] - a[l+1] < x的最小下标, i - r >= m. 所以这是个单调队列dp

#include<bits/stdc++.h>
using namespace std;
#define IOS ios::sync_with_stdio(false) ,cin.tie(0), cout.tie(0);
//#pragma GCC optimize(3,"Ofast","inline")
#define ll long long
#define PII pair<int, char>
//#define int long long
const int N = 3e5 + 5;
const int M = 1e5 + 5;
const int INF = 0x3f3f3f3f;
const ll LNF = 0x3f3f3f3f3f3f3f3f;
const int mod = 998244353;
const double PI = acos(-1.0);
int n, m;
int a[N]; bool f[N]; int q[N];
bool check( int x ) {
  f[0] = 1; int hh = 0, tt = -1;
  for ( int i = 1; i <= n; ++ i ) {
    if( i - m >= 0 && f[i - m] ) q[++tt] = i - m;
    while( hh <= tt && a[i] - a[q[hh] + 1] > x ) ++ hh;
    if( hh <= tt ) f[i] = 1;
  }
  bool ff = f[n];
  for ( int i = 1; i <= n; ++ i ) f[i] = 0;
  return ff;

}
void solve() {
  cin >> n >> m;
  for ( int i = 1; i <= n; ++ i ) cin >> a[i];
  sort(a + 1, a + 1 + n);
  int l = 0, r = 1e9;
  while( l < r ) {
    int mid = l + r >> 1;
    if( check(mid) ) r = mid;
    else l = mid + 1;  
  }
  cout << l << '\n';
}
int main() {
  IOS
  int t = 1; //cin >> t;
  while( t -- ) solve();
  return 0;
}

标签:const,int,Photo,Processing,mid,long,hh,DP,define
来源: https://www.cnblogs.com/muscletear/p/16400084.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有