【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 ...
随机推荐
- VC拷贝字符串到剪切板
] ="中华人民共和国"; DWORD dwLength = ; // 要复制的字串长度 HANDLE hGlobalMemory = GlobalAlloc(GHND, dwLe ...
- 按键精灵MySql数据库操作
查询 MySql服务器地址="192.168.1.166" 用户名 = "root" 密码 = " 数据库名="bookshop" ...
- WordPress404页面自定义
不知道大家是怎么设计404页面,个性的404可以为网站增色不少,wordpress设置404是在主题里面的404.php页面上,当然比如你用Apache.nginx等服务器,你可以自己建一个单页,内容 ...
- oracle中的符号含义
1.Oracle数据库存储过程中:=是什么意思?答:赋值的意思.举例:str := 'abcd';将字符串abcd赋值给变量str. 2.oracle 存储过程中的 := 和=有什么区别?答::= 是 ...
- C/C++——C语言库函数大全
本文转载自:https://blog.csdn.net/yanfan0916/article/details/6450442###; 1. 分类函数: ctype.h int isalpha(int ...
- PDO和mysqli对比
PHP中,如何选择PDO和mysqli呢?本文做个简单的比较 1)总的比较 PDO MYSQLI 数据库支持 12种不同的数据库支持 支持MYSQL API OOP OOP和过程 命名参数 支持 ...
- html基础--css基本属性
HTML基础--css基本属性 <!DOCTYPE html> <html lang="en"> <head> <meta cha ...
- 运行级别(run level)
inittab是很多linux版本的启动脚本.Linux在完成核内引导以后,就开始运行init程序,它的进程号是1,是所有其他进程的起点.init需要读取/etc/inittab,该文件告诉init在 ...
- jq用户评论点击回复简单代码。
类似这种镶套回复评论: <div> <ul> <!--一条评论 begin--> <li> <div class="user-colum ...
- [Ext JS 4] MVC 应用程序框架
前言 大型客户端应用程序总是很难编写,很难组织和很难维护.随着功能的增加和更多的开发人员加入项目,对项目的控制也越来越困难了.Ext JS 4 提供了一个新的应用程序框架帮助组织代码. 模型 - 一组 ...