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/ ...
随机推荐
- Tensorflow学习笔记3:卷积神经网络实现手写字符识别
# -*- coding:utf-8 -*- import tensorflow as tf from tensorflow.examples.tutorials.mnist import input ...
- Codeforces Round #426 (Div. 2) - A
题目链接:http://codeforces.com/contest/834/problem/A 题意:给定4个图标,某些图标经过顺时针/逆时针旋转90°后能得到另外一些图标.现在给你开始的图标和结束 ...
- CondaHTTPError: HTTP 000 CONNECTION FAILED for url <https://mirrors.ustc.edu.cn/anaconda/pkg
conda安装时一直报错,换源什么的都不好使,折腾了半天,直到看到https://blog.csdn.net/u013383596/article/details/87718472 将https改为h ...
- case_when
select sname,score,case when score>=20 and score<30 then 20when score>=30 and score<40 t ...
- Git关联JIRA的issue
指导文章 http://www.51testing.com/html/30/n-3724930.html http://{$host_url}/help/user/project/integratio ...
- 【leetcode】1027. Longest Arithmetic Sequence
题目如下: Given an array A of integers, return the length of the longest arithmetic subsequence in A. Re ...
- MySql 的类型和Java的类型
参考:https://www.cnblogs.com/jerrylz/p/5814460.html 类型名称 显示长度 数据库类型 JAVA类型 JDBC类型索引(int) 描述 ...
- 【Java】Java调用第三方接口
Get请求与Http请求 https://www.w3school.com.cn/tags/html_ref_httpmethods.asp HttpClient HTTP 协议可能是现在 Inter ...
- Win10真正好用之处
第一步. 关闭无用服务 刚装好Win10的时候,整部电脑响应很慢,有时什么都不做,硬盘灯也能狂闪半天.很明显,这是微软爸爸默认开启的服务未被及时关闭所致. 网上有很多文章指导新手如何关闭系统服务,但 ...
- Flask学习 1创建第一个页面
#!/usr/bin/env python # encoding: utf-8 """ @version: v1.0 @author: cxa @file: hello. ...