2021年夏季学期华清大学电子系数算oj2题解

某知名oier锐评蒟蒻的oj1题解:

话不多说,进入oj2题解:

难缠的oj 之 难缠的店长

当时读完我已经因为无良甲方的行为出离愤怒了!
但是做题还是要做!

1.建立链表

本题实际上是链表模板题,但是据学长反映,用我们在《程序设计基础》中接触的以结构体,指针构造节点的办法,并不能ac此题! 回想一下,其实我们在结构体中,存储了指向下一个节点的指针。那么,有没有其他的办法,使得我们可以记录下一个节点的位置呢? 在数组中,我们可以通过下标索引的方法快速访问指定元素。那么,也就是说,我们只要把下一节点的下标想办法存在当前节点,就可以达到与传统链表一样的功能了! 因此,我们只需要再init一个数组,用于存储下一节点的下标,就可以实现常数更优化的访问了!

但是,我们仔细读题发现,店长的要求非常混乱:不仅要添加,删除,调换,甚至要改变全序。这时候,我们发现单向的链表并不能满足题目的要求了。但这并不构成困难,我们只需再init一个数组,构成双向链表结构即可。 然后,我们按照数算老师课上的要求:先继承再添加的原则,一步一步实现题目要求的功能。

理论上,我们需要三个数组:a[i]用于存储当前节点的值,l[i]用于存储当前节点的上一节点的下标,r[i]用于存储当前节点的下一节点的下标。但是,由于本题中恰好有物体的编号从1到n,定义域等于值域,因此可以少建立一个数组,用两个数组实现链表。

2.实现题目要求的功能

2.1 添加节点

添加的物品分为,添加到右边的物体和添加到左边的物体,原理大体相同,现在以把物体添加到左边为例:
首先,为了使得我们从始至终都只有“向一个链表中添加节点”而不存在“从0到1个节点”的过程,我们先初始化两个边界节点,这里我使用了下标0和下标n+1。也就是说,这两个节点始终作为首尾节点存在着,这使得我们不用了考虑建立一个链表的问题。

int i,j,lorr;read(i),read(j),read(lorr);
if(lorr==num){l[i]=l[j],r[l[j]]=i,r[i]=j;l[j]=i;}
else if(lorr==-1){r[0]=i;r[i]=n+1;l[n+1]=i;l[i]=0;}
else{r[i]=r[j];l[r[j]]=i;l[i]=j;r[j]=i;}

如这段代码写的这样,我们在添加节点时,先把原来存在的指针(此处把下标索引称为指针了)继承下来,然后再按照情况添加新的。注意不要漏写,必须保证每个节点与左右节点都是双向的。

2.2 删除节点

删除节点与添加节点几乎同理,仍然是对l,r数组进行操作。

int ri=r[i],li=l[i];
l[ri]=li,r[li]=ri;l[i]=0;r[i]=0;

此处不进行冗余的解释。

2.3 调换操作

按照我们前两步的思维,调换节点无非就是删除两个节点,再添加两个节点。确实,对于大多数节点,这样的做法是正确的。但是,如果你要调换的两个节点正好相邻,那么,由于删除和添加操作都涉及到对相邻节点的操作,可能会出现问题。可能不会,我不知道,请自行实践。因此,对于相邻的节点,我们可以引入特判。

int i,j;read(i),read(j);
if(r[i]==j){
int li=l[i],rj=r[j];
r[li]=j,l[rj]=i,r[j]=i,l[i]=j,r[i]=rj,l[j]=li;
}
else if(r[j]==i){
int ri=r[i],lj=l[j];
r[lj]=i,l[ri]=j,r[i]=j,l[j]=i,r[j]=ri,l[i]=lj;
}
else{
int li=l[i],ri=r[i],lj=l[j],rj=r[j];
r[li]=j,l[j]=li,l[ri]=j;r[j]=ri;
r[lj]=i,l[i]=lj,l[rj]=i,r[i]=rj;
}

2.4 改变全序

看起来这一步最为丧心病狂,但是,实际上,只要我们记住当前翻转的总次数,然后按照需要的顺序输出就好了!

else if(boo==-2){num++;num=num&1;}

附上ac代码

#include<cstdio>
#include<ctype.h>
using namespace std;
int l[200005],r[200005];
inline void read(int&x){
char c,f=x=0;
while(!isdigit(c=getchar()))f=c=='-';
while(isdigit(c))x=x*10-48+c,c=getchar();
if(f)x=-x;
}
int main(){
int n,m,k,u,num=0;read(n),read(m),read(k),read(u);
r[0]=n+1;l[n+1]=0;
for(int i=1;i<=n+m+k+u;i++){
int boo;read(boo);
if(boo==1){
int i,j,lorr;read(i),read(j),read(lorr);
if(lorr==num){l[i]=l[j],r[l[j]]=i,r[i]=j;l[j]=i;}
else if(lorr==-1){r[0]=i;r[i]=n+1;l[n+1]=i;l[i]=0;}
else{r[i]=r[j];l[r[j]]=i;l[i]=j;r[j]=i;}
}
else if(!boo){
int i;read(i);
int ri=r[i],li=l[i];
l[ri]=li,r[li]=ri;l[i]=0;r[i]=0;
}
else if(boo==-1){
int i,j;read(i),read(j);
if(r[i]==j){
int li=l[i],rj=r[j];
r[li]=j,l[rj]=i,r[j]=i,l[i]=j,r[i]=rj,l[j]=li;
}
else if(r[j]==i){
int ri=r[i],lj=l[j];
r[lj]=i,l[ri]=j,r[i]=j,l[j]=i,r[j]=ri,l[i]=lj;
}
else{
int li=l[i],ri=r[i],lj=l[j],rj=r[j];
r[li]=j,l[j]=li,l[ri]=j;r[j]=ri;
r[lj]=i,l[i]=lj,l[rj]=i,r[i]=rj;
}
}
else if(boo==-2){num++;num=num&1;}
}
if(num){int i=n+1;while(l[i]){printf("%d ",l[i]);i=l[i];}}
else {int i=0;while(r[i]-n-1){printf("%d ",r[i]);i=r[i];}}
printf("-1");
}

通过快读得到了60ms的坏成绩

2021夏季学期华清大学EE数算OJ2:难缠的店长的更多相关文章

  1. 2021夏季学期华清大学EE数算OJ1:算数问题

    第一次写博客,有点紧张... 也许格式也没有特别丑吧 先看原题( 此题做法众多,这里仅仅介绍蒟蒻的一种很复杂的思路(但最后还是喜提0ms的好成绩) 读完这道题,不难发现,此题不过是一个质因数分解+一堆 ...

  2. 2021春季学期华清大学EE数算OJ3:岩石的重量

    原题目如下: 看起来,这不过是我们在<程序设计基础>里面接触过的简单动态规划问题(什么,你不知道什么叫动态规划? 什么是动态规划? 百度百科对"动态规划"一词定义如下: ...

  3. 毕业样本=[华威大学毕业证书]Warwick原件一模一样证书

    华威大学毕业证[微/Q:2544033233◆WeChat:CC6669834]UC毕业证书/联系人Alice[查看点击百度快照查看][留信网学历认证&博士&硕士&海归& ...

  4. 热烈庆祝华清远见2014嵌入式系统(Linux&Android)开发就业培训课程全面升级

    近日,华清远见公开宣布:2014嵌入式系统 (Linux&Android)开发就业培训课程再次升级!据悉,华清远见如今已经持续10年,一直保持课程每年2次的更新的频率.华清远见的每 次课程更新 ...

  5. 基于华清远见STM32f051的 IIC从模式实现方法

    作者:卢老师,华清远见嵌入式学院讲师. 在大多情况下,我们使用MCU控制传感器,节点以及相关从设备,但在较为复杂的系统中,有时候也会使用MCU做为从设备. 下面是关于stm32f051的从模式实现方法 ...

  6. 热烈祝贺华清远见《ARM处理器开发详解》第2版正式出版

    2014年6月,由华清远见研发中心组织多名业 内顶尖讲师编写的<ARM处理器开发详解>一书正式出版.本书以S5PV210处理器为平台,详细介绍了嵌入式系统开发的各个主要环节,并注重实践,辅 ...

  7. [华清远见]FPGA公益培训

    本套视频教程为华清远见 网络公益培训活动,主讲人:姚远老师,华清远见高级讲师. ------------------------------------------------------------ ...

  8. 华清远见Linux设备驱动(每章小结)

    1.  linux设备驱动是以内核模块的方式而存在的,在具体的驱动开发中将驱动编译为模块具有很到的工程意义.因为如果将正在开发中的驱动编译如内核,而开发过程中会不断修改驱动代码,则需要不断的编译和重启 ...

  9. hdu 5228 OO’s Sequence(单独取数算贡献)

    Problem Description OO has got a array A of size n ,defined a function f(l,r) represent the number o ...

随机推荐

  1. vim的vimrc配置

    windows "# modified by Neoh set helplang=cn "使用中文帮助文档 set encoding=utf-8 "查看utf-8格式的帮 ...

  2. h4ck47h0n ? h4ck3r ? I"m just a coder......

    [0x00]刚开了专栏,没事过来投投稿混眼熟啦~//才不是为了抱枕呢刚刚结束了黑客马拉松,回来也是缓了好久才缓过来.这么高强度的脑洞劳动···阿不,是脑力劳动的说.真的第一次.说起来,跟代码相识,还是 ...

  3. Emscripten教程之代码可移植性与限制(一)

    Emscripten教程之代码可移植性与限制(一) 翻译:云荒杯倾本文是Emscripten-WebAssembly专栏系列文章之一,更多文章请查看专栏.也可以去作者的博客阅读文章.欢迎加入Wasm和 ...

  4. python-排列组合序列

    [题目描述]用户输入整数n(1<=n<=26)和整数m(m<=n),然后输入n个不同的字母,请编写程序输出在这n个字母中选择m个字母的所有排列序列和组合序列. [练习要求]请给出源代 ...

  5. IDEA中 mybatis-config、applicationContext.xml、log4j.properties、SpringMVC等文件没有图标标识符号,不是一个xml文件

    1. 举例说明 mybatis-config.xml文件不显示图标,识别不出该xml文件 2. 解决办法 1)先点击 File -> Settings-,然后贴入下面代码 (2) 具体操作如下图 ...

  6. CentOS系统Tomcat 8.5或9部署SSL证书

    本文档介绍了CentOS系统下Tomcat 8.5或9部署SSL证书的操作说明. 环境准备 操作系统:CentOS 7.6 64位 Web服务器:Tomcat 8.5或9 前提条件 已从阿里云SSL证 ...

  7. 判断H5页面是在小程序的webview环境中,还是在微信环境中,还是不在微信

    <script src="https://res2.wx.qq.com/open/js/jweixin-1.6.0.js" type="text/javascrip ...

  8. 获取bootstrap模态框点击的对应项(e.relatedTarget.dataset)

    //获取绑定的自定义属性值<ul> <li data-toggle="modal" data-index="电表1111" data-targ ...

  9. vs技巧 - 调试asp.net core源码

    学习asp.net core的方式除了看官方文档,看源码是也是一种很好的方式.本文介绍一种方法,简单配置vs,无需第三方插件就可以将asp.net core的源码链接自己的项目,随时穿梭于core的源 ...

  10. git设置本地与远程分支关联

    1.为了避免每次都进行验证,在git进行绑定ssh mkdir ~/.ssh ssh-keygen -t rsa -C "xxx@qq.com" 将生成的公钥粘贴到git中 2.本 ...