下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
NOIP2008(twostack)题解这道题大概可以归结为如下题意:1(q1),2(q2)1(s1)2(s2).最初的时候,q2,s1s2q1n(n<=1000)1~naq1s1bs1q1q2cq1s2d操作,将s2的栈顶元素弹出并加入q1q2的队列尾.q21,2,3,…,n.可以,求出字典序最小的一个操作序列.这道题的错误做法很多,错误做法却能得满分的也很多,这里就不多说了.直接切入正题,就是即将介绍的这个基于二分图的算法.注意到并没有说基于二分图匹配,因为这个算法和二分图匹配无关.这个算法只是用到了给一个图着色成二分图.第一步需要解决的问题是,判断是否有解.q1[i]q1[j]pk,i<j<kq1[k]<q1[i]<q1[j].p,结论很显然,使用反证法可证.假设这两个数压入了同一个栈,那么在压入q1[k]的时候栈内情况如下:…q1[i]…q1[j]…q1[k]q1[i]q1[j]q1[kq21,2,3,…,n而之后,无论其它的数字在什么时候被弹出,q1[jq1[i]q1[j]>q1[i],这显然是不正确的.p.p,一定可以压入同一个栈."不满足条件p有两种情况:一种是对于任意i<j<k且q1[i]<q1[j],q1[k]>q1[i];另一种是对于任意i<j,q1[i]>q1[j].q1[k]被压入栈的时候,q1[i]么,q1[k]q1[j]产生任何影响(这里可能有点乱,因为看起来,当q1[j]<q1[kr,j<k<rq1[r]<q1[j]<q1[k]r,q1[k]q1[j]没有影响).第二种情况下,我们可以发现这其实就是一个降序序列,所以所有数字都可以压入同一个栈.这样,原命题的逆否命题得证,所以原命题得证.pq1[i]q1[j]不能压入同一个栈的充要条件也得证.这样,我们对所有的数对(i,j)1<=i<j<=n,i<j<kijp1[j]不能压入同一个栈.此时想到了什么?那就是二分图~二分图的两部分看作两个栈,因为二分图的同一部分内不会出现任何连边,也就相当于不能压入同一个栈的所有结点都分到了两个栈中.O(n)以得知是否有解.此时,检查有解的问题已经解决.接下来的问题是,如何找到字典序最小的解.121s1,为2s2.s1.又发现二分图的不同连通分量之间的染色是互不影响的,所以可以每次选取一个未染色的编号最小的结点,将它染色为1DFS染色为止.这样,我们就得到了每个结点应该压入哪个栈中.接下来要做的,只不过是模拟之后输出序列啦~还有一点小问题,就是如果对于数对(i,j),kO(n^3).解决方法就是,首先预处理出数组b,b[i]表示从p1[i]到p1[n](i,j)b[j+1p1[i]p1[i]p1[j]就可以了.附代码(除去注释不到100行),带注释.代码中的a数组对应文中的队列p1.已经过掉所有标准数据,以及5724163这组让很多贪心程序挂掉的数据~1#include<iostream>23usingnamespacestd;45constintnn=1002,mm=nn*2,inf=1000000000;intn,tot,now;inta[nn],b[nn],head[nn],color[nn];intadj[mm],next[mm];intstack[3][nn];boolresult;111213voidaddEdge(intxinty//加边14{15 ++tot;[]==head[x];=tot;19}202122booldfs(inti//DFS染色,检查图是否是二分图的经典算法23{24 inttemp=head[i];2526 while(temp//邻接表,检查每一条边27 {282930色
if(!color[adj[temp]])//如果与当前结点的结点还未染31 {3233
[p3r进行染色34 [p;35 }36 if(color[adj[temp]]==color[i])returnfalse;3738解
//如果两个相邻结点染色相同,说明此图不是二分图,返回无next[temp];41 }42 returntrue;43}4445intmain()46{freopen("twostack.in","r",stdin);freopen("twostack.out","w",stdout);495051 //输入52 scanf("%d",&n);53 for(inti=1;i<=n;++i)scanf("%d",&a[i]);545556 //b数组57 n+]=58 for(inti=n;i>=1;--i)b[i]=min(b[i+1],a[i]);59//"min"inSTL6061//枚举数对(i,j)并加边tot=0;for(inti=1;i<=n;++i)for(intj=i+1;j<=n;++j)66 if(b[j+1]<a[i]&&a[i]<a[j])67 {j);i);70 }7172//DFS染色memset(color,0,sizeof(color));result=true;76for(inti1in//每次找当前未染色的编号最, , 798081 if(color[i])//当前位置尚未被染色82 {83 ]=1;84if(dfs(i//染色时出现矛盾,此时图不是一个二分图,即无法分配到两个栈中87 {888990break;91}92}938990break;91}92}9394if(!result//无解printf("0");9798 else//有解99 {100101102103
//模拟求解now=1;for(inti=1;i<=n;++i)104105106107
{//将当前数字压入对应的栈if(color[i]==1)printf("a");elseprintf("c");[i][ir]=];//thiswillworkevenifstack[1][0]=0//循环检查,如果可以的话就从栈顶弹出元素while(stack[1][stack[1][0]]==now||stack
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025版简易工伤赔偿协议书范本-娱乐行业工伤赔偿3篇
- 2025版跨区域货运风险分担货物运输保险协议3篇
- 2024年物联网农业技术开发与合作协议
- 2024年中国移动式交通信号灯市场调查研究报告
- 四川2024下半年四川省林业科学研究院招聘10人笔试历年典型考点(频考版试卷)附带答案详解
- 2024年经销商协作协议范本版B版
- 2024年版无财产有未成年子女离婚合同模板一
- 2025版现代办公场所厂房租赁合作协议书
- 2024年03月“梦想靠岸”招商银行长春分行春季校园招考笔试历年参考题库附带答案详解
- 2025年度智慧农业设施包清工承包合同范本3篇
- 九年级物理下册 第十五章 电功和电热 二 电功率教案 (新版)苏科版
- 小学体育教案《50米快速跑(途中跑)》
- 八年级物理上册 第六章 第1节 质量教案 (新版)新人教版
- 中职2024-2025学年高一上学期期末语文试题06(解析版)
- 耕作学智慧树知到期末考试答案章节答案2024年中国农业大学
- 2024年中国消防救援学院第二批面向应届毕业生招聘28人历年【重点基础提升】模拟试题(共500题)附带答案详解
- QCT1067.5-2023汽车电线束和电器设备用连接器第5部分:设备连接器(插座)的型式和尺寸
- 【基于近五年数据的五粮液公司财务分析案例6400字】
- 16J916-1住宅排气道一
- 2024质量管理理解、评价和改进组织的质量文化指南
- 《YST 550-20xx 金属热喷涂层剪切强度的测定》-编制说明送审
评论
0/150
提交评论