题目

【题目描述】
K 理事长是占卜好手,他精通各种形式的占卜。今天,他要用正面写着 `I` ,背面写着 `O` 的卡片占卜一下日本 IOI 国家队的选手选择情况。
占卜的方法如下:
1. 首先,选取五个正整数 $A,B,C,D,E$;
2. 然后,拿出 $A+B+C+D+E$ 张卡片摆成一排,从左至右摆成 $A$ 张正面,$B$ 张反面,$C$ 张正面,$D$ 张反面,$E$ 张正面的形式。也就是说,从左到右依次摆 $A$ 张 `I`,$B$ 张 `O`,$C$ 张 `I`,$D$ 张 `O`,$E$ 张 `I`;
3. 再从预先确定的 $N$ 种操作中选择 $1$ 种以上,然后按照自己喜欢的顺序进行操作,同样的操作可以进行 $1$ 次及以上。第 $i$ 种操作是「把从左到右第 $L_i$ 张卡片到第 $R_i$ 张卡片(包括两端)翻过来」,因为需要用手操作,所以翻 $1$ 张牌需要花费 $1$ 秒,完成一次操作需要花费 $R_i-L_i+1$ 秒;
4. 操作后,如果所有牌都是正面朝上的,占卜就结束了。
因为这种占卜比较费时,所以 K 理事长在占卜之前想知道占卜能否结束,如果能结束,他想知道占卜的最小耗时。
【输入格式】
第一行,五个正整数 $A,B,C,D,E$,意义如题目描述;
第二行,一个正整数 $N$,意义如题目描述;
接下来 $N$ 行描述操作,一行两个正整数 $L_i,R_i$,意义如题目描述。
【输出格式】
输出一行,如果占卜能够结束,则输出一个正整数,表示占卜的最小耗时;如不能,输出 $-1$。
【样例输入一】
1 2 3 4 5
3
2 3
2 6
4 10
【样例输出一】
12
【样例解释一】
最初的卡片序列为 `IOOIIIOOOOIIIII`;
先进行第二个操作,卡片序列变为 `IIIOOOOOOOIIIII`,花费 $5$ 秒;
再进行第三个操作,卡片序列变为 `IIIIIIIIIIII`,这个操作花费 $7$ 秒,一共花费 $12$ 秒。
可以证明,$12$ 秒为占卜的最小耗时,因此输出 $12$。
【样例输入二】
1 1 1 1 1
1
1 1
【样例输出二】
-1

题解

考虑覆盖,从 $ i $ 覆盖到 $ j $ 相当于通过那些翻转,从 $ i $ 走到 $ j $(画图手动感知)

然后就变成了最短路,分别枚举起点和终点就可以了

(本题卡 int)

代码

 #include<bits/stdc++.h>
#define LL long long
#define _(d) while(d(isdigit(ch=getchar())))
using namespace std;
int R(){
int x;bool f=;char ch;_(!)if(ch=='-')f=;x=ch^;
_()x=(x<<)+(x<<)+(ch^);return f?x:-x;}
const int N=5e5+;
int n,a[],head[N],cnt;LL dis[N],ans=2e18;
struct edge{int to,nex,w;}e[N<<];
struct node{
int x;LL w;
bool friend operator <(node a,node b){return a.w>b.w;}
};priority_queue<node>q;
void add(int s,int t,int w){e[++cnt]=(edge){t,head[s],w},head[s]=cnt;}
void dij(int s){
for(int i=;i<=a[];i++)dis[i]=2e18;
dis[s]=;
q.push((node){s,});
while(!q.empty()){
node now=q.top();q.pop();
if(now.w!=dis[now.x])continue;
for(int v,k=head[now.x];k;k=e[k].nex)
if(dis[v=e[k].to]>dis[now.x]+e[k].w)
dis[v]=dis[now.x]+e[k].w,q.push((node){v,dis[v]});
}
return;
}
int main(){
for(int i=;i<=;i++)a[i]=a[i-]+R();
n=R();
for(int i=,u,v;i<=n;i++)
u=R()-,v=R(),add(u,v,v-u),add(v,u,v-u);
dij(a[]);
LL s1=dis[a[]],s2=dis[a[]],s3=dis[a[]];
dij(a[]);
ans=min(min(ans,s2+dis[a[]]),s3+dis[a[]]);
dij(a[]);
ans=min(ans,s1+dis[a[]]);
printf("%lld\n",ans==2e18?-:ans);
return ;
}

【JOI Camp 2015】IOIO卡片占卜——最短路的更多相关文章

  1. IOIOI卡片占卜(Atcoder-IOIOI カード占い)(最短路)

    题目描述: K 理事長は占いが好きで,いつも様々な占いをしている.今日は,表の面に ‘I’ が,裏の面に ‘O’ が書か れたカードを使って今年の IOI での日本選手団の出来を占うことにした. 占い ...

  2. 「JOISC 2015 Day 1」卡片占卜

    题目描述 K 理事长是占卜好手,他精通各种形式的占卜.今天,他要用正面写着 I ,背面写着 O 的卡片占卜一下日本 IOI 国家队的选手选择情况. 占卜的方法如下: 首先,选取五个正整数 A,B,C, ...

  3. [BZOJ4103][Thu Summer Camp 2015]异或运算 可持久化Trie树

    4103: [Thu Summer Camp 2015]异或运算 Time Limit: 20 Sec  Memory Limit: 512 MB Description 给定长度为n的数列X={x1 ...

  4. [Thu Summer Camp 2015]解密运算

    4104: [Thu Summer Camp 2015]解密运算 Time Limit: 10 Sec  Memory Limit: 512 MB Description 对于一个长度为N的字符串,我 ...

  5. 【BZOJ 4104】 4104: [Thu Summer Camp 2015]解密运算 (智商)

    4104: [Thu Summer Camp 2015]解密运算 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 370  Solved: 237 De ...

  6. 【BZOJ 4103】 4103: [Thu Summer Camp 2015]异或运算 (可持久化Trie)

    4103: [Thu Summer Camp 2015]异或运算 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 474  Solved: 258 De ...

  7. 【NOIP2015模拟11.3】IOIOI卡片占卜

    题目 K理事长很喜欢占卜,经常用各种各样的方式进行占卜.今天,他准备使用正面写着"I",反面写着"O"的卡片为今年IOI的日本代表队占卜最终的成绩. 占卜的方法 ...

  8. 【题解】LOJ2759. 「JOI 2014 Final」飞天鼠(最短路)

    [题解]LOJ2759. 「JOI 2014 Final」飞天鼠(最短路) 考虑最终答案的构成,一定是由很多飞行+一些上升+一些下降构成. 由于在任何一个点上升或者下降代价是一样的,所以: 对于上升操 ...

  9. bzoj:4105: [Thu Summer Camp 2015]平方运算

    Description   Input 第一行有三个整数N,M,p,分别代表序列的长度.平方操作与询问操作的总次数以及在平方操作中所要模的数.   接下来一行N个数代表一开始的序列{X1,X2,... ...

随机推荐

  1. Javascript代码收集

    1.模仿jquery each 原文地址 function each(obj, fn){ var i; if(Object.prototype.toString.call(obj) === '[obj ...

  2. yhdsir@function:php

    curl 获取页面信息 function curl_get_content($url){ $curl = curl_init(); curl_setopt($curl, CURLOPT_URL, $u ...

  3. PAT 天梯赛 L3-003. 社交集群 【并查集】

    题目链接 https://www.patest.cn/contests/gplt/L3-003 思路 并查集 用一个 cou[i] 来表示 第 i 门课程 的第一个 感兴趣的人 并的时候 判断 cou ...

  4. BA模型 第10章

    1.BA模型BA模型就是世界坐标到像素坐标的转换过程.这里多了一个去畸变.因为归一化平面坐标在转成像素坐标的过程中会出现畸变.这里只处理了径向畸变,径向畸变包括桶形失真和枕形失真,都是由于图像放大率随 ...

  5. 草原psd素材

    草原PSD素材,草原,风景,蓝天白云,飞鸟,阳光,绿色,草地. http://www.huiyi8.com/caoyuan/psd/

  6. ASM磁盘组mount一例

    环境信息: oracle10gRAC  +  RHEL5.8 问题现象: db1服务器crs服务正常,ASM的data磁盘组处于dismount状态.db2集群服务正常. SQL> select ...

  7. 分享知识-快乐自己:自定义struts2类型转换的全局与局部错误信息。

    遇到类型转换错误的时候(也就是说不能进行类型转换),struts2框架自动生成一条错误信息,并且将该错误信息放到addFieldError里面.我们可以通过配置文件来替换这条由struts2自动生成的 ...

  8. ZOJ 3805 Machine(二叉树,递归)

    题意:一颗二叉树,求  “  宽度  ” 思路:递归,貌似这个思路是对的,先记下,但是提交时超时, 1.如果当前节点只有左孩子,那么当前宽度等于左孩子宽度 2.如果当前节点只有右孩子,那么当前宽度等于 ...

  9. tensorflow kmeans 聚类

    iris: # -*- coding: utf-8 -*- # K-means with TensorFlow #---------------------------------- # # This ...

  10. (转)HLS协议,html5视频直播一站式扫盲

    本文来自于腾讯bugly开发者社区,原文地址:http://bugly.qq.com/bbs/forum.php?mod=viewthread&tid=1277 视频直播这么火,再不学就 ou ...