UOJ Easy Round#7
UOJ Easy Round#7
传送门:http://uoj.ac/contest/35
题解:http://matthew99.blog.uoj.ac/blog/2085
#1
题意:
在一个(2n+1)*(2n+1)的网格中,每次只能走到相邻的点,
从左上端出发到右下端,找到一条路径,使此路径经过的所有点权值和最小。
输入:从内到外输出每一圈的点值大小;数据范围n<=10^5;
比赛中:
拿到题目,看到那极有特色性的一个大方格,以及极为特殊的走法,和那10^5的数据量,算法上基本可以确定贪心;
根据直觉,知道最短路径肯定是从左上角绕到某里圈一层的左上角,然后再从里圈的左上角沿着路线走到这一圈的右下角,然后再按照对称性跑到右下角;
关键是如何使从左上角到里圈左上角的路径最短,我同学提出了很多方法,但大多的问题是有后效性,或者是会Tle;
找不到思路后,我决定按照直觉敲n^2dp;
实际得分:50分;
#2
题意:给定一个长度为n的序列,输出所有的ans使
k∈[2,n],ans=min{MAXi-MINi}i∈所有长度为k的区间;
且如果答案与标准答案相差不超过5%,也算做正确;(吐槽:近似算法都出出来了,这真的是noip难度吗?)
比赛中:关键信息是题目中允许近似这一点上,做过bzoj遥远的行星这题的估计都对近似有些印象;
在开始考虑如何近似之后,我发现很难做,基本无思路;
但50%的数据比较好搞,两个for循环搞定;
实际得分:50分;
#3
题意:求最大的ans=max(s(l,r)*(r-l))
s(l,r)表示l到r这个区间之间所有数之间的最小的差的绝对值;
比赛中:此时已经心理崩溃,在看到这题没几个人交之后,决定放弃,思考前面的题目(尽管最后也没思考出什么结果);
实际得分:0分
总体评价:在看完了题解之后,我发现这套题还真不是很难,至少都处于可写范围内:第一题贪心,第二题近似,第三题分块,而且算法都不是十分复杂,代码量都很小;
但为什么没做好,只搞到了100分呢?
一是没有清晰的思路,甚至于没有思路;
先说没有清晰的思路,第一题其实我们已经找到了切入点,极为明显的贪心痕迹和数据量帮助了我们;
我们已经知道了该如何做了,但是没有找到接下来的路(主要是没有解决后效性的问题);
后来我看题解了后仔细思考了下,其实我的想法已经很接近答案了,但没有用画图,设未知数等方法进行仔细的分析,轻易放弃了;
再说没有思路,第二题第三题就属于这样,题中要求的信息很复杂,又是min,max又是区间之类的,这需要训练;
但也能大致发现这些题目中的一些规律:一般说来,对序列问题,分而治之是解决这些题目最有力方法,信息合并比较容易的话,可以考虑线段树之类的东西;如果信息合并不太容易,就像这次的第三题,合并一次O(n),总的复杂度O(n^2),这样的一般就需要考虑一下分块;
代码:
第一题:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<string>
#include<algorithm>
#include<ctime>
#include<cmath>
using namespace std;
#define LL long long
#define up(i,j,n) for(int i=j;i<=n;i++)
#define down(i,n,j) for(int i=n;i>=j;i--)
const int maxn=;
int n;
int a[maxn];
LL ans=1LL<<,minn=1LL<<,sum=;
int main(){
scanf("%d",&n);n++;
down(i,n,)scanf("%d",&a[i]);
up(i,,n){
minn=min(minn,(LL)a[i]);
if(a[i]==minn)ans=min(ans,(sum<<)+(*(n-i)+)*(LL)a[i]);
sum+=minn+a[i];
}
printf("%lld\n",ans);
return ;
}
第二题:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<string>
#include<algorithm>
#include<ctime>
#include<cmath>
using namespace std;
#define LL long long
#define up(i,j,n) for(int i=j;i<=n;i++)
#define down(i,n,j) for(int i=n;i>=j;i--)
const int maxn=,inf=;
namespace OI{
const double c=1.05;
int n;
int a[maxn];
int q[maxn],head=,tail=;
int Q[maxn],Head=,Tail=;
void slove(){
scanf("%d",&n);
up(i,,n)scanf("%d",&a[i]);
double L=;
for(int k=;k<=n;k++){
L*=c;
int t=k+(int)L-;
if(t>n)t=n,L=t-k+;
int v=(k+t)>>;
int ans=inf;
Head=,Tail=;head=,tail=;
for(int i=;i<=n;i++){
while(head<=tail&&i-q[head]+>v)head++;
while(head<=tail&&a[q[tail]]<=a[i])tail--;
q[++tail]=i;
while(Head<=Tail&&i-Q[Head]+>v)Head++;
while(Head<=Tail&&a[Q[Tail]]>=a[i])Tail--;
Q[++Tail]=i;
if(i>=v)ans=min(ans,a[q[head]]-a[Q[Head]]);
}
up(i,,(int)L)printf("%d\n",ans);
k=t;
}
return;
}
}
int main(){
using namespace OI;
slove();
return ;
}
第三题:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<string>
#include<algorithm>
#include<ctime>
#include<cmath>
using namespace std;
#define LL long long
#define up(i,j,n) for(int i=j;i<=n;i++)
#define down(i,n,j) for(int i=n;i>=j;i--)
#define max(x,y) ((x)>(y)?(x):(y))
#define min(x,y) ((x)<(y)?(x):(y))
#define abs(x) ((x)<0?(-(x)):(x))
template<typename T>inline bool chkmax(T &a,T b){return a<b?a=b,true : false;}
template<typename T>inline bool chkmin(T &a,T b){return a>b?a=b,true : false;}
int read(){
int x=;char ch=getchar();bool flag=;
while(ch<''||ch>''){if(ch=='-')flag=;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return flag?-x:x;
}
namespace OI{
const int maxn=,inf=;
int n,m,k,S;
LL ans=;
int a[maxn];
int b[maxn<<];
int f[maxn];
int now[maxn];
void slove(){
scanf("%d%d%d",&n,&m,&k);
S=max(,(int)sqrt(m*1.0)+);
up(i,,n)a[i]=read();
memset(f,,sizeof(f));
int mx=-;
for(int L=;L<=S;++L){
mx=-;
for(int i=;i<=n-L+;++i){
chkmin(f[i],min(abs(a[i]-a[i+L-]),f[i+]));
chkmax(mx,f[i]);
}
if(L>=k)chkmax(ans,(LL)mx*(L-));
}
for(int i=;i<=n;++i){
for(int j=;j<=S;++j){
if(j&&i-now[j]>=k)chkmax(ans,(i-now[j]-)*(LL)j);
chkmax(now[j+],now[j]);
if(a[i]-j>)chkmax(now[j+],b[a[i]-j]);
if(a[i]+j<=m)chkmax(now[j+],b[a[i]+j]);
}
b[a[i]]=i;
}
printf("%lld\n",ans);
return;
}
}
int main(){
using namespace OI;
slove();
return ;
}
顺便说一句:常看看别人的代码是个好习惯,能get一些不错的技巧;
“;第七套广播体操,原地踏步——走!”
众所周知,跳蚤们最喜欢每天早起做早操,经常天还没亮就齐刷刷地站在操场做着反复纵跳热热身。跳晚国在研制三星 note7 的时候注意到了这点,于是他们打算让炸弹更快地引爆,这样就可以消灭更多早起的跳蚤。
三星 note7 的主板可以看作是由 (2n+1)×(2n+1)(2n+1)×(2n+1) 个中继器构成的,某些中继器会有导线连在一起,左上角和右下角的中继器分别连着电源的正负极。
电流流过一根导线的时间可忽略不计,但当电流经过中继器时,会延缓一段时间再从中继器流出。这个时间只跟该中继器本身有关,我们把这段时间的长度称为中继器的延时值。
这些中继器由导线连接围成一个一个的层,同个层的中继器的种类都一样,而不同层的种类都不一样,可以发现总共有 n+1n+1 层。当 n=4n=4 时,主板大概长这样:
跳晚们打算再加几根导线将某些中继器连接起来.凭借发达的重工业,他们能生产出无数条导线。但由于主板的限制,他们的导线只能和主板四周的边平行,且其长度只够连接相邻两个中继器。
现在他们想知道,他们改造的三星 note7 的电源正极流出的电流能在多短的时间到达电源负极从而造成短路,这样电池就会释放出巨大的能量摧毁跳蚤国的有生力量了。
请参考输入格式和样例配图来更好地理解题意。
输入格式
第一行一个正整数 nn。
第二行 n+1n+1 个正整数 a0,a1,…,ana0,a1,…,an,表示从内到外每层的中继器的延时值,单位为秒。其中,第 ii 行第 jj 列的中继器的延时值为(1≤i,j≤n1≤i,j≤n)
输出格式
输出一行一个数表示改造后的最短引爆时间。
C/C++ 输入输出 long long 时请用 %lld
。C++ 可以直接使用 cin/cout 输入输出。
UOJ Easy Round#7的更多相关文章
- 【UOJ Easy Round #1】
数论/Trie/并查集 猜数 这题我是这样分析的…… $a*b=g*l=n=k^2 \ and \ (g|a,g|b) \Rightarrow (g*a')*(g*b' )=g*l=k^2 \\ \R ...
- UOJ Easy Round #5
Preface 本着刷遍(只刷一遍)各大OJ的原则我找到了一场UOJ的比赛 无奈UOJ一般的比赛难度太大,我就精选了UER中最简单的一场打了一下,就当是CSP前的练习吧 A. [UER #5]万圣节的 ...
- 【UOJ Easy Round #2】
然而UER我也照样跪…… 第一题 忘了取模sad || 操作符将整个区间分成了一些段,每个手机只会执行其中某一段,执行次数为这一段中&&的个数?+1? ans=ans*num[i]+1 ...
- UOJ Test Round 1
第一题: 题目大意: 给出N个字符串,字符串的前面部分都是字母且都是一样的,后面部分是数字,按照后面的数字排序.N<=10000 解题过程: 1.第一题是真良心,一开始的做法是把后面的数字分离出 ...
- UOJ Test Round #2
昨天晚上打的这个比赛,简直一颗赛艇啊-- 感觉发挥的并不好.比赛的时候比较紧张,最后一题还脑残写了个离散化结果爆零了,哎我怎么这么逗逼-- 讲讲比赛经过吧. 比赛之前逗逼地以为是8:00开始,然后淡定 ...
- YZOI Easy Round 2_回文串 string
原文链接:http://laphets1.gotoip3.com/?id=18 Description 给出一个由小写字母组成的字符串,其中一些字母被染黑了,用?表示.已知原来的串不是 一个回文串,现 ...
- YZOI Easy Round 2_化简(simplify.c/cpp/pas)
Description 给定一个多项式,输出其化简后的结果. Input 一个字符串,只含有关于字母x 的多项式,不含括号与分式,没有多余的空格. Output 一个字符串,化简后的多项式,按照次数从 ...
- [模拟赛FJOI Easy Round #2][T3 skill] (最小割+最大权闭合子图(文理分科模型))
[题目描述] 天上红绯在游戏中扮演敏剑,对于高攻击低防御的职业来说,爆发力显得非常重要,为此,她准备学习n个技能,每个技能都有2个学习方向:物理攻击和魔法攻击.对于第i个技能,如果选择物理攻击方向,会 ...
- [模拟赛FJOI Easy Round #2][T1 sign] (模拟+求字符串重复字串)
[题目描述] 小Z在无意中发现了一个神奇的OJ,这个OJ有一个神奇的功能:每日签到,并且会通过某种玄学的算法计算出今日的运势.在多次试验之后,小Z发现自己的运势按照一定的周期循环,现在他找到了你,请通 ...
随机推荐
- VUE之Router命令行警告:Named Route 'Home' has a default child route. 解决办法
Named Route 'Home' has a default child route. When navigating to this named route (:to="{name: ...
- Xamarin.Forms支持的地图显示类型
Xamarin.Forms支持的地图显示类型 在Xamarin.Forms中,专门提供了一个Map视图,用来显示地图.根据用户的需求不同,该视图支持三种地图显示类型,用户可以通过Map视图提供的M ...
- linux jar 命令使用
原文链接:http://blog.chinaunix.net/uid-692788-id-2681136.html JAR包是Java中所特有一种压缩文档,其实大家就可以把它理解为.zip包.当然也是 ...
- Revolving Digits
题面 [题目描述]: 有一天,Silence对可以旋转的正整数十分感兴趣.在旋转操作中,他可以把后面的数字按照原位置不动地搬到剩下位置的前面.当然,他也可以完全不动这串数字.比如,他可以把123变为1 ...
- nginx和php通信
#启动php-fpm服务 #配置nginx.conf worker_processes ; worker_rlimit_nofile ; worker_cpu_affinity ; #error_lo ...
- iOS--实时监控网络状态的改变
在网络应用中,有的时候需要对用户设备的网络状态进行实时监控,有两个目的: (1)让用户了解自己的网络状态,防止一些误会(比如怪应用无能) (2)根据用户的网络状态进行智能处理,节省用户流量,提高用户体 ...
- 使用sqlalchemy查询并删除数据表的唯一性索引
简单描述表结构,字段类型 desc tabl_name 删除索引:alter table `db`.`table_name` drop index `index_name` 注意里面的特殊符号: ` ...
- Boost.Asio c++ 网络编程翻译(18)
同步服务端 同步服务端也相当简单.它须要两个线程,一个负责接收新的client.另外一个负责处理已经存在的client. 它不能使用单线程:等带一个新的client是一个堵塞操作,所以我们须要另外一个 ...
- tomcat启动文件
home目录下创建run.bat文件,文件内容如下: @echo off set JAVA_OPTS=-server -Xms1024m -Xmx1024m ^-XX:+UseG1GC ^-XX:Ma ...
- hql 时间
1.hql中时间格式转换 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); String d ...