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. buuctf 荷兰带宽数据泄露

    荷兰带宽数据泄露 下载附件得一个conf.bin文件,这个文件是路由信息文件,题目并没有任何提示,我们先来测试一下最简单的,找username或password然后当作flag交上去,我们使用Rout ...

  2. 深入理解ES6之《ES7》

    指数运算符 Math.pow是可以进行求幂运算的求幂运算符是两个星号 let result = 5 ** 2 console.log(result) //25 console.log(result = ...

  3. 微信小程序调研

    小程序入口 微信发现,小程序 公众号主体查看小程序 好友分享,群分享 公众号自定义菜单跳转 APP页面跳转 第三方服务 附近的小程序 扫普通链接二维码打开小程序 需要后台开启功能,开启后,用户在微信& ...

  4. python-输入输出-计算字符串中的数

    将字符串中的每个数都抽取出来,然后统计所有数的个数并求和. 输入格式: 一行字符串,字符串中的数之间用1个空格或者多个空格分隔. 输出格式: 第1行:输出数的个数.第2行:求和的结果,保留3位小数. ...

  5. java中什么是局部内部类Local inner class?

    5.局部内部类Local inner class 马克-to-win:什么叫局部内部类?内部类声明位置:1.它的外部类的范围之内.2.在几个程序块的范围之内.例如,由方法定义的块中或甚至在for循环体 ...

  6. java中什么是内部类?它有什么用?如何使用?

    什么是内部类?马克-to-win:一句话:类中还有类.里边的叫内部类, 外边的叫外层类.有什么用?1)像文件夹一样,文件放文件夹里更清晰,内部类放外层类中, 清晰.主要从编程序的逻辑角度出发,有用.比 ...

  7. java中递归的用法和例子

    递归   直接或者间接调用自己, public class Test{    public static void main(String[] args){        int i = 5;    ...

  8. 给一个非矩形数组(Nonrectangular Arrays)

    Nonrectangular Arrays(非矩形数组)  public class Test {     public static void main(String[] args) {       ...

  9. Spring理解1 ioc

    Spring Spring是一个轻量级的控制反转(IOC)和面向切面(AOP)的容器(框架).   需要了解 ioc容器 IOC底层原理 IOC接口 BeanFactory Bean的作用域 IOC操 ...

  10. 使用Socket实现HttpServer(三)

    使用Socket实现HttpServer(三) 这一章继续对我们的服务器进行优化,引入 NIO package com.fengsir.network.step4; import java.io.IO ...