ZOJ 2706 Thermal Death of the Universe
Thermal Death of the Universe
Time Limit: 10 Seconds Memory Limit: 32768 KB
Johnie has recently learned about the thermal death concept. Given that the Global Entropy always increases, it will end in the thermal death of the Universe. The idea has impressed him extremely. Johnie does not want the universe to die this way.
So he decided to emulate the process to check how soon the thermal death can occur. He has created the mathematical model of the process in the following way. The universe is represented as an array of n integer numbers. The life of the universe is represented as the sequence of the following entropy operations: take elements from ith to jth and replace them with their average value. Since their average is not necessarily integer, it is rounded.
To keep balance, rounding is performed either up, or down depending on the current sum of all elements of the array. If their sum is less or equal to the sum of the original array, the rounding is performed up, in the other case --- down.
Given the initial array and the sequence of the entropy operations, find the contents of the resulting array.
Input
There are mutiple cases in the input file.
The first line of each case contains n and m --- the size of the array and the number of operations respectively (1 <= m, n <= 30,000 ). The second line contains n integer numbers --- the initial contents of the array, they do not exceed 109 by their absolute value. The following m lines contain two integer numbers each and describe entropy operations.
There is an empty line after each case.
Output
Output n integer numbers --- the contents of the array after all operations.
There should be am empty line after each case.
Sample Input
6 4
1 2 3 4 5 6
1 2
2 5
5 6
4 6
Sample Output
2 3 3 5 5 5
赤裸裸的一条线段树,然后需要延时更新~~注意细节就是求值的时候要强转换成(LL)(r-l +1)*v
#include <bits/stdc++.h> #define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define lr rt<<1
#define rr rt<<1|1 using namespace std; typedef long long LL;
const int N = ; LL osum;
int n,q; struct ST
{
int l,r;
LL lazy,date;
int mid(){
return (l+r)>>;
}
}st[N<<]; void push_down(int rt)
{
if( st[rt].lazy )
{
st[lr].lazy = st[rr].lazy = st[rt].lazy;
st[lr].date = (LL)( st[lr].r - st[lr].l + ) * st[lr].lazy;
st[rr].date = (LL)( st[rr].r - st[rr].l + ) * st[rr].lazy;
st[rt].lazy=;
}
} void build(int l,int r,int rt)
{
st[rt].l=l,st[rt].r=r;
st[rt].lazy=;
if(l==r)
{
scanf("%lld",&st[rt].date);
osum += st[rt].date;
return ;
} int m=st[rt].mid();
build(lson);
build(rson);
st[rt].date = st[rr].date + st[lr].date;
} void update(int l,int r,int rt,LL v)
{
if( l == st[rt].l && st[rt].r == r )
{
st[rt].date= (LL) ( r - l + ) * v ;
st[rt].lazy=v;
return;
} push_down(rt); int m=st[rt].mid(); if( l > m )
update(l,r,rr,v);
else if(r <= m)
update(l,r,lr,v); else{
update(lson,v);
update(rson,v);
}
st[rt].date = st[rr].date + st[lr].date; } LL query(int l,int r,int rt)
{ if( l==st[rt].l && r==st[rt].r )
{
return st[rt].date;
} push_down(rt); int m=st[rt].mid(); if(l > m)
return query(l,r,rr); else if( r <= m)
return query(l,r,lr); else
return query(lson)+query(rson);
} void show(int rt)
{
if(st[rt].l == st[rt].r)
{
printf("%lld",st[rt].date);
if(st[rt].r != n)printf(" ");
else printf("\n");
return;
}
int m=st[rt].mid();
push_down(rt);
show(lr);
show(rr);
} int main()
{
int x,y;
// freopen("in.txt","r",stdin);
while(~scanf("%d%d",&n,&q)){
osum=;
build(,n,);
while(q--)
{
scanf("%d%d",&x,&y);
if(x>y)swap(x,y);
LL tmp = query(x,y,);
double ave = (long double)tmp/(y-x+);
if( st[].date <= osum ) update(x, y,,(LL)ceil(ave));
else update( x, y, ,(LL)floor(ave) );
}
show();
puts("");
}
return ;
}
ZOJ 2706 Thermal Death of the Universe的更多相关文章
- ZOJ 2706 Thermal Death of the Universe (线段树)
题目链接:ZOJ 2706 Thermal Death of the Universe (线段树) 题意:n个数.m个操作. 每一个操作(a,b)表示(a,b)全部值更新为这个区间的平均数:1.当前的 ...
- zoj 2706 线段树
题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=1706 trick:关于正数和负数的整除问题,正数整除是自动向下取整的 ...
- Soj题目分类
-----------------------------最优化问题------------------------------------- ----------------------常规动态规划 ...
- [转]Hooked on DTrace
source link: 1.http://blog.bignerdranch.com/1907-hooked-on-dtrace-part-1/ 2.http://blog.bignerdranch ...
- HDU 3689 Infinite monkey theorem [KMP DP]
Infinite monkey theorem Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Oth ...
- hdu 3689 杭州 10 现场 J - Infinite monkey theorem 概率dp kmp 难度:1
J - Infinite monkey theorem Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d &am ...
- hdu 3689 Infinite monkey theorem
Infinite monkey theorem Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/ ...
- HDU 3689 Infinite monkey theorem(DP+trie+自动机)(2010 Asia Hangzhou Regional Contest)
Description Could you imaging a monkey writing computer programs? Surely monkeys are smart among ani ...
- HUD3689 Infinite monkey theorem
Infinite monkey theorem Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/ ...
随机推荐
- ASE Beta Sprint - backend scrum 4
本次scrum于2019.12.10在sky garden进行,持续10分钟. 参与人: Xin Kang, Zhikai Chen, Lihao Ran, Hao Wang 请假: Ning Jia ...
- 2018-11-15-UWP-how-to-get-the-touch-width
title author date CreateTime categories UWP how to get the touch width lindexi 2018-11-15 18:49:12 + ...
- 一、IIS性能检测与网站管理
一.性能监视器 1.Windows Server自带的性能监视器.(开始 运行 perfmon ) 另一种方式打开 Performance Monitor 点击Windows+R,在Run中输入per ...
- python常用函数 Y
yield有点像return,但他会在下一次执行的时候从上次结束点继续执行,带有 yield 的函数在 Python 中被称之为 generator(生成器),生成器无法通过索引获取数据,同时也承诺使 ...
- 函数柯里化(Currying)小实践
什么是函数柯里化 在计算机科学中,柯里化(Currying)是把接受多个参数的函数变换成接受一个单一参数(最初函数的第一个参数)的函数,并且返回接受余下的参数且返回结果的新函数的技术.这个技术由 Ch ...
- zabbix agentd错误日志解决办法
公司新上了一台服务器,我安装了zabbix_agents软件包,并复制了zabbix server端的zabbix_agentd.conf到/etc/zabbix里面并修改了相关的参数,并启动了zab ...
- No Spring Session store is configured: set the 'spring.session.store-type'
发现session store type使用来存放session的存储方式,目前Spring boot中只支持Redis方式. 由于本应用暂无需将session放入redis的需求,故这里就可以将se ...
- Change the environment variable for python code running
python程序运行中改变环境变量: Trying to change the way the loader works for a running Python is very tricky; pr ...
- simulate 中的一些操作
1. neutralize: position based 的alpha int neutralize(int di, int ti) { ; ; ; ; ii < nsyms; ++ii) { ...
- Telegraf根据配置文件启动(Influxdb的数据收集)
1.创建一个telegraf.config文件 telegraf -sample-config -input-filter cpu:disk:diskio:net:system:mem -output ...