NOI.AC NOIP模拟赛 第一场 补记
NOI.AC NOIP模拟赛 第一场 补记
candy
题目大意:
有两个超市,每个超市有\(n(n\le10^5)\)个糖,每个糖\(W\)元。每颗糖有一个愉悦度,其中,第一家商店中的第\(i\)颗糖果的愉悦度为\(A_i\),而第二家商店中的第\(i\)颗糖果的愉悦度为\(B_i\)。
在每家商店买的糖果会被打包到一个袋子中(可以在一家商店什么都不买,此时认为这家商店的袋子为空)。因为这两个袋子外观是一样的,所以会从两个袋子中随机选择一个,然后吃光里面的糖果。定义一种买糖果的方案的愉悦度为:吃到的糖果的愉悦度之和的最小可能值。
求买糖果的愉悦度与买糖果的花费之差的最大值。
思路:
显然对于一家店,购买相同数量的糖果,一定选择愉悦度尽量高的更优。
因此将\(A_i\)和\(B_i\)从大到小排序,求前缀和。答案就是\(\max\{\min(A_i,B_j)-(i+j)W\}\)。枚举每一个\(A_i,B_j\)作为\(\min\),然后另一个数就可以通过二分求出来。
时间复杂度\(\mathcal O(n\log n)\)。
源代码:
#include<cstdio>
#include<cctype>
#include<algorithm>
inline int getint() {
register char ch;
while(!isdigit(ch=getchar()));
register int x=ch^'0';
while(isdigit(ch=getchar())) x=(((x<<2)+x)<<1)+(ch^'0');
return x;
}
typedef long long int64;
const int N=1e5+1;
int64 a[N],b[N];
int main() {
const int n=getint(),m=getint();
for(register int i=1;i<=n;i++) a[i]=getint();
for(register int i=1;i<=n;i++) b[i]=getint();
std::reverse(&a[1],&a[n]+1);
std::reverse(&b[1],&b[n]+1);
for(register int i=1;i<=n;i++) a[i]+=a[i-1];
for(register int i=1;i<=n;i++) b[i]+=b[i-1];
int64 ans=0;
for(register int i=0;i<=n;i++) {
const int j=std::lower_bound(&b[0],&b[n]+1,a[i])-b;
if(j<=n) ans=std::max(ans,a[i]-(int64)(i+j)*m);
}
for(register int i=0;i<=n;i++) {
const int j=std::lower_bound(&a[0],&a[n]+1,b[i])-a;
if(j<=n) ans=std::max(ans,b[i]-(int64)(i+j)*m);
}
printf("%lld\n",ans);
return 0;
}
sort
来源:
Ufa SATU + Bucharest U Contest J. Reverse Sort
题目大意:
一个长度为\(n(n\le50000)\)的序列\(A\)。每次操作可以将一个区间翻转,定义翻转区间\([l,r]\)的代价为\(r-l+1\)。要通过翻转将这个序列排序,请你构造出代价小小于\(2\times10^7\)的一种方案。
思路:
当\(A_i\in\{0,1\}\)时,用归并排序的思想,每次归并时将左子区间的后缀\(1\)与右子区间的前缀\(0\)交换即可。
而没有\(A_i\in\{0,1\}\)的条件时,我们可以利用快速排序的思想,每次从区间内随机选取一个数\(x\)作为基准,\(\le x\)的数作为\(0\),\(>x\)的数作为\(1\)。然后内层套用上述归并排序的算法。
源代码:
#include<cstdio>
#include<cctype>
#include<climits>
#include<algorithm>
inline int getint() {
register char ch;
while(!isdigit(ch=getchar()));
register int x=ch^'0';
while(isdigit(ch=getchar())) x=(((x<<2)+x)<<1)+(ch^'0');
return x;
}
const int N=5e4+1;
int a[N];
inline bool check(const int &b,const int &e) {
for(register int i=b;i<e;i++) {
if(a[i]>a[i+1]) return false;
}
return true;
}
void solve(const int &b,const int &e,const int &x) {
if(b==e) return;
const int mid=(b+e)>>1;
solve(b,mid,x);
solve(mid+1,e,x);
int p=b,q=e;
while(p<=mid&&a[p]<=x) p++;
while(q>mid&&a[q]>x) q--;
if(p<=mid&&q>mid) {
printf("%d %d\n",p,q);
std::reverse(&a[p],&a[q]+1);
}
}
void solve(const int &b,const int &e) {
if(b>=e) return;
if(check(b,e)) return;
const int x=a[b+rand()%(e-b+1)];
solve(b,e,x);
for(register int i=b;i<=e;i++) {
if(a[i]>x) {
solve(b,i-1);
solve(i,e);
return;
}
}
solve(b,e);
}
int main() {
srand(998244353);
const int n=getint();
for(register int i=1;i<=n;i++) a[i]=getint();
solve(1,n);
puts("-1 -1");
return 0;
}
NOI.AC NOIP模拟赛 第一场 补记的更多相关文章
- NOI.AC NOIP模拟赛 第二场 补记
NOI.AC NOIP模拟赛 第二场 补记 palindrome 题目大意: 同[CEOI2017]Palindromic Partitions string 同[TC11326]Impossible ...
- NOI.AC NOIP模拟赛 第四场 补记
NOI.AC NOIP模拟赛 第四场 补记 子图 题目大意: 一张\(n(n\le5\times10^5)\)个点,\(m(m\le5\times10^5)\)条边的无向图.删去第\(i\)条边需要\ ...
- NOI.AC NOIP模拟赛 第三场 补记
NOI.AC NOIP模拟赛 第三场 补记 列队 题目大意: 给定一个\(n\times m(n,m\le1000)\)的矩阵,每个格子上有一个数\(w_{i,j}\).保证\(w_{i,j}\)互不 ...
- NOI.AC NOIP模拟赛 第五场 游记
NOI.AC NOIP模拟赛 第五场 游记 count 题目大意: 长度为\(n+1(n\le10^5)\)的序列\(A\),其中的每个数都是不大于\(n\)的正整数,且\(n\)以内每个正整数至少出 ...
- NOI.AC NOIP模拟赛 第六场 游记
NOI.AC NOIP模拟赛 第六场 游记 queen 题目大意: 在一个\(n\times n(n\le10^5)\)的棋盘上,放有\(m(m\le10^5)\)个皇后,其中每一个皇后都可以向上.下 ...
- contesthunter暑假NOIP模拟赛第一场题解
contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...
- NOI.AC NOIP模拟赛R3解题报告
心路历程 预计得分:\(100+100+50=250\) 实际得分:\(10 +100 +50 = 160\) 三道原题,真好.T2做过,T1写了个错误思路,T3写了写50分状压dp. 整场考试实际在 ...
- 计蒜客 NOIP 提高组模拟竞赛第一试 补记
计蒜客 NOIP 提高组模拟竞赛第一试 补记 A. 广场车神 题目大意: 一个\(n\times m(n,m\le2000)\)的网格,初始时位于左下角的\((1,1)\)处,终点在右上角的\((n, ...
- [NOI.AC 2018NOIP模拟赛 第三场 ] 染色 解题报告 (DP)
题目链接:http://noi.ac/contest/12/problem/37 题目: 小W收到了一张纸带,纸带上有 n个位置.现在他想把这个纸带染色,他一共有 m 种颜色,每个位置都可以染任意颜色 ...
随机推荐
- 怎么在sublime里面显示编码格式
我要在sublime text里面显示编码格式 点击Preference—settings 然后再user里面加入这个 // Display file encoding in the status b ...
- 一个ssm综合小案例-商品订单管理----写在前面
学习了这么久,一直都是零零散散的,没有把知识串联起来综合运用一番 比如拦截器,全局异常处理,json 交互,RESTful 等,这些常见技术必须要掌握 接下来呢,我就打算通过这么一个综合案例把这段时间 ...
- Mybatis 使用 mapper 接口规范的 一对一, 一对多,多对多映射
首先的 是 最原始的 pojo 类来 做简单映射 简单 pojo 映射: <mapper namespace="com.ghc.dao.UserDao"> <se ...
- jquery或者js对html控件的处理汇总
1.下拉列表select的处理 a).后台通过jquery获取的json数据对下拉列表select的赋值操作: html页面:<select name="gameserverlist& ...
- Oracle 基本操作符
1.一般操作符 (1)!= 不等于 select empno,ename,job from scott.emp where job!='manager' (2)^= 不等于 select empno, ...
- blog迁移
blog迁移到: https://github.com/for-firecat/
- 【API】文件操作编程基础-CreateFile、WriteFile、SetFilePointer
1.说明 很多黑客工具的实现是通过对文件进行读写操作的,而文件读写操作实质也是对API函数的调用. 2.相关函数 CreateFile : 创建或打开文件或I/O设备.最常用的I/O设备如下:文件,文 ...
- python模块分析之time和datetime模块
前言 我们使用time和datetime模块的主要目的是对时间戳.时间字符串.时间元组等时间的表述对象进行相互的转化.而我们平时编码涉及两个时间:一个是上海时间,也可以说是北京时间,一个是UTC时间, ...
- 使用InstallShield打包windriver驱动-转
转自:http://blog.csdn.net/weixin_29796711/article/details/72822052 用户在使用我们用windriver开发的硬件驱动时,需要先安装wind ...
- mysql主从复制跳过复制错误【转】
跳过复制错误 mysql因为binlog机制问题,有些时候会出现从库重放sql执行失败的情况,特别是旧的STATEMENT模式最容易出现这种情况(因为函数和存储过程等原因),这也是为什么强调使用mix ...