GAME——转圈游戏
我们在生命的路上常常绝望 大概是因为弯路走了太多
脚上的泡被磨起又磨破
像我们所有的幻想与梦 起起落落。
所以说 我这道题考场上面和题解想得一模一样啊啊啊啊啊啊啊啊啊啊!!!!!!
但是就是打复杂了啊啊啊啊啊啊啊啊!!!!!!!!!!!!!!!!!!!!
为什么我每次一看到环就感觉自己被耍了啊啊啊啊啊啊!!!!!!
自己的写法大概是有一个head tail记录环的首尾这样比较的时候就可以方便跳 然后我还加了一个-1的处理保证被合并了的不再被处理
考场上改了蛮久不过最后还是爆零啦
标程给出的方法是用了一个l数组和一个r数组
这个数被合并了就把它的r赋给左边的r
就相当于通过lr的操作把它挤掉
好无奈啊这么简单又机智的办法我居然没想到
因为lr数组那边处理起来还是有点问题所以标解是手打快排了的
这是标解
#include<iostream> #include<cstdio> #include<cstring> #include<cstdlib> #include<cmath> #include<ctime> #include<queue> #define inf 2147483647 #define fre(z) freopen(z".in","r",stdin),freopen(z".out","w",stdout) #define my long long #define d "%lld" using namespace std; ; my getint(); my n; my a[N+]; my w[N+]; my l[N+],r[N+]; my ans; void qsort(my,my); ////////////在一个环中每次选择两个相邻元素,分数加上两个元素之差,然后把小的元素移除,问分数之和的最小值是多少 ////////////贪心 //证明: //对于当前环中最小值k以及k的相邻两个元素k_l,k_r //把他与相邻数操作后一定是自己移除 //然后每次合并后留下的是最大值 //所以如果先合并k_l及k_l左边的元素或k_r及k_r右边的元素,那么合并后k相邻两个元素的值>=k_l,k_r //所以首先合并k_l或k_r肯定更优 //然后肯定要合并min(k_l,k_r) //然后直接删除k即可 int main() { fre("game"); n=getint(); ;i<=n;i++) w[i]=i,a[i]=getint(),l[i]=i-,r[i]=i+; l[]=n;r[n]=; qsort(,n); ;T<n;T++) { my i=w[T]; cout<<i<<" "<<l[i]<<" "<<r[i]<<" "<<a[i]<<endl; ans+=min(a[l[i]],a[r[i]])-a[i]; l[r[i]]=l[i];r[l[i]]=r[i]; } printf(d,ans); ; } my getint() { my w=; ; char c=getchar(); ') && c!='-') c=getchar(); ,c=getchar(); +c-',c=getchar(); return q? -w:w; } void qsort(my l,my r) { my i=l,j=r,mid=a[w[(i+j)>>]]; while (i<=j) { while (a[w[i]]<mid) i++; while (a[w[j]]>mid) j--; if (i<=j) { w[]=w[i]; w[i]=w[j]; w[j]=w[]; i++; j--; } } if (i<r) qsort(i,r); if (l<j) qsort(l,j); }
然而作为一个彻头彻尾sort党很不服气
于是强行一波
#include<iostream> #include<cstdio> #include<cstdlib> #include<algorithm> #include<cstring> #define N 100030 #define ll long long using namespace std; struct hh { ll v,id,l,r; }a[N]; ll ans=,n; ll b[N]; bool cmp(hh x,hh y){return x.v<y.v;} int main(){ freopen ("game.in","r",stdin); freopen ("game.out","w",stdout); scanf ("%lld",&n); ;i<=n;++i){ scanf ("%lld",&a[i].v); a[i].id=i,a[i].l=i-,a[i].r=i+; } a[].l=n,a[n].r=; sort(a+,a+n+,cmp); ;i<=n;++i) b[a[i].id]=i; ;i<n;++i){ ans+=min(a[b[a[i].l]].v,a[b[a[i].r]].v)-a[i].v; a[b[a[i].r]].l=a[i].l,a[b[a[i].l]].r=a[i].r; } cout<<ans; ; }
那么这个悲惨的故事告诉我们处理问题的时候尽量简化
因为想多了要处理的细节多了反而瞬间爆炸
还不如把事情最简化一下
GAME——转圈游戏的更多相关文章
- [快速幂][NOIP2012]转圈游戏
转圈游戏 题目描述 n 个小伙伴(编号从 0 到 n-1)围坐一圈玩游戏.按照顺时针方向给 n 个位置编号,从0 到 n-1.最初,第 0 号小伙伴在第 0 号位置,第 1 号小伙伴在第 1 号位置, ...
- 3285 转圈游戏 2013年NOIP全国联赛提高组
3285 转圈游戏 2013年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description n 个小伙伴 ...
- codevs3285转圈游戏
传送门 3285 转圈游戏 2013年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题解 题目描述 Descript ...
- 洛谷 P1965 转圈游戏
洛谷 P1965 转圈游戏 传送门 思路 每一轮第 0 号位置上的小伙伴顺时针走到第 m 号位置,第 1 号位置小伙伴走到第 m+1 号位置,--,依此类推,第n − m号位置上的小伙伴走到第 0 号 ...
- 1617:转圈游戏 ybt
1617:转圈游戏 时间限制: 1000 ms 内存限制: 524288 KB提交数: 540 通过数: 326 [题目描述] nn 个小伙伴(编号从 00 到 n−1n−1 ...
- 题解 【NOIP2013】转圈游戏
[NOIP2013]转圈游戏 Description n个小伙伴(编号从0到n-1)围坐一圈玩游戏.按照顺时针方向给n个位置编号,从0到n-1.最初,第0号小伙伴在第0号位置,第1号小伙伴在第1号位置 ...
- luoguP1965 转圈游戏(NOIP2013)(快速幂)
luogu P1965 转圈游戏 题目 #include<iostream> #include<cstdlib> #include<cstdio> #include ...
- 洛谷P1965 转圈游戏 [2013NOIP提高组 D1T1][2017年6月计划 数论04]
P1965 转圈游戏 题目描述 n 个小伙伴(编号从 0 到 n-1)围坐一圈玩游戏.按照顺时针方向给 n 个位置编号,从0 到 n-1.最初,第 0 号小伙伴在第 0 号位置,第 1 号小伙伴在第 ...
- 快速幂——while理解&&[P1965] 转圈游戏
快速幂--while理解 \[a^k\] 把k转成2进制 \[k=2^n*p[n]+2^(n-1)*p[n-1]+...+2^1*p[1]+2^0*p[0]\] \[a^k=a^(2^n*p[n]+2 ...
- Java实现 蓝桥杯 算法提高 转圈游戏(暴力快速幂)
试题 算法提高 转圈游戏 问题描述 n 个小伙伴(编号从 0 到 n-1)围坐一圈玩游戏.按照顺时针方向给 n 个位置编号,从0 到 n-1.最初,第 0 号小伙伴在第 0 号位置,第 1 号小伙伴在 ...
随机推荐
- css中的float和position
1.float <!DOCTYPE html> <html lang="en"> <head> <meta charset="U ...
- selenium与表格的二三事
今天遇到的问题是selenium与表格中行和列的问题! 我想要做的事情是统计当前的table有多少行,表格形式如下如所示: 图中所示为2行,我的定位方式是这样的 : table=driver.find ...
- 【深度学习系列】用PaddlePaddle和Tensorflow实现AlexNet
上周我们用PaddlePaddle和Tensorflow实现了图像分类,分别用自己手写的一个简单的CNN网络simple_cnn和LeNet-5的CNN网络识别cifar-10数据集.在上周的实验表现 ...
- .net程序员做的第一个安卓APP
我从毕业之后一直做的是ASP.NET,从毕业到现在都已经五六个年头了.一个事物接触久了就会慢慢没有了新鲜感热情也褪去的差不多了,我又是对新事物比较感兴趣的,虽说Android早就不算什么新事物,当对于 ...
- expressjs 支持umeditor 的图片上传
umedtor 的文件上传 是form 提交. 请求的header Accept: text/html,application/xhtml+xml,application/xml;q=0.9,imag ...
- 51Nod--1006 lcs
1006 最长公共子序列Lcs 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 收藏 关注 给出两个字符串A B,求A与B的最长公共子序列(子序列不要求是连续的). ...
- 《Clean Code》 代码简洁之道
作者介绍 原文作者: Robert C. Martin, Object Mentor公司总裁,面向对象设计.模式.UML.敏捷方法学和极限编程领域的资深顾问,是<敏捷软件开发:原则.模式.与实践 ...
- MySQL-Select语句高级应用
1.1 SELECT高级应用 1.1.1 前期准备工作 本次测试使用的是world数据库,由mysql官方提供下载地址: https://dev.mysql.com/doc/index-other.h ...
- Ali RocketMQ与Kafka对照
淘宝内部的交易系统使用了淘宝自主研发的Notify消息中间件,使用Mysql作为消息存储媒介.可全然水平扩容,为了进一步减少成本.我们觉得存储部分能够进一步优化,2011年初,Linkin开源了Kaf ...
- 天津政府应急系统之GIS一张图(arcgis api for flex)解说(三)显示地图坐标系模块
config.xml文件的配置例如以下: 1 2 <widget left="3" bottom="3" config="widgets/Coo ...