【8.30校内测试】【找规律模拟】【DP】【二分+贪心】

对于和规律或者数学有关的题真的束手无策啊QAQ
首先发现两个性质:
1、不管中间怎么碰撞,所有蚂蚁的相对位置不会改变,即后面的蚂蚁不会超过前面的蚂蚁或者落后更后面的蚂蚁。
2、因为所有蚂蚁速度一样,不管标号的话两只蚂蚁的碰撞相当于直接互相穿过,所以最初有多少蚂蚁方向向左,最后就有多少蚂蚁从左落下,向右同理。
总结一下又可以发现,比如有$cntl$只蚂蚁最初向左,$cntr$只蚂蚁最初向右,那么最后就是原位置的左边连续$cntl$只从左落下,原位置右边连续$cntr$只从右落下。我们将所有方向向左和向右的蚂蚁落下的时间分别排序,和原序列上一一对应即可。
#include<iostream>
#include<cstdio>
#include<algorithm>
#define LL long long
using namespace std; int n, b[], cntl, cntr;
LL a[], L;
double ans[], l[], r[]; int main ( ) {
freopen ( "ant.in", "r", stdin );
freopen ( "ant.out", "w", stdout );
scanf ( "%I64d%d", &L, &n );
for ( int i = ; i <= n; i ++ ) scanf ( "%I64d", &a[i] );
for ( int i = ; i <= n; i ++ ) scanf ( "%d", &b[i] );
for ( int i = ; i <= n; i ++ )
if ( !b[i] )
l[++cntl] = a[i];
else r[++cntr] = L - a[i];
sort ( l + , l + + cntl );
sort ( r + , r + + cntr );
for ( int i = ; i <= cntl; i ++ )
ans[i] = l[i];
for ( int i = ; i <= cntr; i ++ )
ans[n - i + ] = r[i];
for ( int i = ; i <= n; i ++ )
printf ( "%.2lf ", ans[i] );
return ;
}
见8.20校内测试,题目转换一下就一模一样了。

数据比较水,写的$O(nlog_nlog_h)$完全够了。
二分最小值,$check$的时候贪心修改区间,我用的线段树,判断一下就好了。实际上差分复杂度更优。写线段树的时候无聊写了区间求和??
#include<iostream>
#include<cstdio>
#include<algorithm>
#define LL long long
using namespace std; int n, K;
LL T, a[]; LL TR[], tag[], vc[]; void update ( int nd ) {
TR[nd] = TR[nd << ] + TR[nd << | ];
} void push_down ( int nd, int l, int r ) {
if ( tag[nd] ) {
int mid = ( l + r ) >> ;
TR[nd << ] += tag[nd] * ( mid - l + );
TR[nd << | ] += tag[nd] * ( r - mid );
tag[nd << ] += tag[nd];
tag[nd << | ] += tag[nd];
tag[nd] = ;
}
} void build ( int nd, int l, int r ) {
TR[nd] = ; tag[nd] = ;
if ( l == r ) {
TR[nd] = a[vc[l]];
return ;
}
int mid = ( l + r ) >> ;
build ( nd << , l, mid );
build ( nd << | , mid + , r );
update ( nd );
} void add ( int nd, int l, int r, int L, int R, LL d ) {
if ( l >= L && r <= R ) {
TR[nd] += ( r - l + ) * d;
tag[nd] += d;
return ;
}
push_down ( nd, l, r );
int mid = ( l + r ) >> ;
if ( L <= mid ) add ( nd << , l, mid, L, R, d );
if ( R > mid ) add ( nd << | , mid + , r, L, R, d );
update ( nd );
} LL query ( int nd, int l, int r, int pos ) {
if ( l == r ) return TR[nd];
push_down ( nd, l, r );
int mid = ( l + r ) >> ;
if ( pos <= mid ) return query ( nd << , l, mid, pos );
else return query ( nd << | , mid + , r, pos );
} bool check ( LL mid ) {
int tot = ; LL sum = ;
for ( int i = ; i <= n; i ++ )
if ( a[i] < mid ) vc[++tot] = i;
build ( , , tot );
vc[++tot] = 0x7f7f7f7f7f7f7f;
for ( int i = ; i < tot; i ++ ) {
LL now = query ( , , tot - , i );
if ( now >= mid ) continue;
if ( mid - now + sum > T ) { sum = T + ; break; }
int to = vc[i] + K - ;
int pos = upper_bound ( vc + , vc + + tot, to ) - vc - ;
add ( , , tot - , i, pos, mid - now );
sum += mid - now;
}
if ( sum <= T ) return ;
return ;
} LL MI = 0x3f3f3f3f, MA;
LL erfen ( ) {
LL l = MI, r = MA + T, ans;
while ( l <= r ) {
int mid = ( l + r ) >> ;
if ( check ( mid ) ) l = mid + , ans = mid;
else r = mid - ;
}
return ans;
} int main ( ) {
freopen ( "watering.in", "r", stdin );
freopen ( "watering.out", "w", stdout );
scanf ( "%d%d%I64d", &n, &K, &T );
for ( int i = ; i <= n; i ++ ) scanf ( "%I64d", &a[i] ), MI = min ( MI, a[i] ), MA = max ( MA, a[i] );
LL ans = erfen ( );
printf ( "%I64d", ans );
return ;
}
【8.30校内测试】【找规律模拟】【DP】【二分+贪心】的更多相关文章
- 找规律/数位DP HDOJ 4722 Good Numbers
题目传送门 /* 找规律/数位DP:我做的时候差一点做出来了,只是不知道最后的 is_one () http://www.cnblogs.com/crazyapple/p/3315436.html 数 ...
- Codeforces D. Little Elephant and Interval(思维找规律数位dp)
题目描述: Little Elephant and Interval time limit per test 2 seconds memory limit per test 256 megabytes ...
- 洛谷 P1014 Cantor表【蛇皮矩阵/找规律/模拟】
题目描述 现代数学的著名证明之一是Georg Cantor证明了有理数是可枚举的.他是用下面这一张表来证明这一命题的: 1/1 1/2 1/3 1/4 1/5 … 2/1 2/2 2/3 2/4 … ...
- 2017年icpc西安网络赛 Maximum Flow (找规律+数位dp)
题目 https://nanti.jisuanke.com/t/17118 题意 有n个点0,1,2...n-1,对于一个点对(i,j)满足i<j,那么连一条边,边权为i xor j,求0到n- ...
- Codeforces Round #260 (Div. 2) A , B , C 标记,找规律 , dp
A. Laptops time limit per test 1 second memory limit per test 256 megabytes input standard input out ...
- hdu 1998 奇数阶魔方(找规律+模拟)
应该不算太水吧. 17 24 1 8 15 23 5 7 14 16 4 6 13 20 22 10 12 19 21 3 11 18 ...
- 【8.17校内测试】【模拟】【set】【网络流】
为什么每次想的最久的题得的分数最低!!!qwqwq 再也不在noip上尝试A*叻!! 模拟题,先把能消的消掉,双指针从两端向中间扫描,如果头尾合并可以消,就把它消掉,最后判断一下.因为消完过后num保 ...
- PAT 甲级 1049 Counting Ones (30 分)(找规律,较难,想到了一点但没有深入考虑嫌麻烦)***
1049 Counting Ones (30 分) The task is simple: given any positive integer N, you are supposed to co ...
- Codeforce-CodeCraft-20 (Div. 2)-B. String Modification (找规律+模拟)
Vasya has a string s of length n. He decides to make the following modification to the string: Pick ...
随机推荐
- 从urllib和urllib2基础到一个简单抓取网页图片的小爬虫
urllib最常用的两大功能(个人理解urllib用于辅助urllib2) 1.urllib.urlopen() 2. urllib.urlencode() #适当的编码,可用于后面的post提交 ...
- 爬虫--PySpider框架
PySpider框架 PySpider框架的作用
- bzoj 1072 状压DP
我们用w[i][j]来表示,i是一个二进制表示我们选取了s中的某些位,j表示这些位%d为j,w[i][j]则表示这样情况下的方案数,那么我们可以得到转移.w[i|(1<<k)][(j*10 ...
- 给vim安装YouCompleteMe
要安装YouCompleteMe ,vim须支持python.看是否支持,可以在vim中:version 查看, 如果python前有+号,就是支持,减号就是不支持. 如果不支持,需要以编译安装方式重 ...
- arch点击硬盘无法挂载
出现问题如下 在使用xfce4桌面的时候在点击硬盘图标时可以挂载虽然要求你输入root密码 但是在使用openbox的时候点击硬盘图标却出现如下提示,权限的问题 Not authorized to p ...
- PHP7+Nginx的配置与安装教程详解
下面脚本之家小编把PHP7+Nginx的配置与安装教程分享给大家,供大家参考,本文写的不好还请见谅. 系统环境:centos6.5 x64 软件版本:nginx-1.10.0 php-7.0.6 安装 ...
- uboot makefile构建分析-续
前言 这篇博文是 uboot makefile构建分析的续篇,继续分析uboot构建u-boot.bin的过程 构建u-boot.bin过程分析 makefile一开始,就是确定链接脚本.在构建ubo ...
- 初学Memcached安装及使用【转】
1.yum install memcached安装memecached 2.chkconfig memcached on设置memcached开机启动 3.service memcached star ...
- 未找到与约束 ContractName Microsoft.VisualStudio.Utilitues.IContentTypeRegistryService......
1.问题提出 用VS 2013 with Update5 开发项目,点击项目中的文件,发现打不开,抛出如下的错误. 错误提示: 未找到与约束 ContractName Microsoft.Visual ...
- java并发容器
同步容器将所有对容器状态的访问都串行化,以实现线程安全性.这种方式的缺点是严重降低并发性.Java 5.0提供了多种并发容器来改进同步容器的性能.如ConcurrentHashMap代替同步且基于散列 ...