第十三届蓝桥杯Java B 组国赛 C 题——左移右移(AC)
创始人
2024-05-26 16:11:37
0

目录

  • 1.左移右移
    • 1.题目描述
    • 2.输入格式
    • 3.输出格式
    • 4.样例输入
    • 5.样例输出
    • 6.数据范围
    • 6.原题链接
  • 2.解题思路
  • 3.Ac_code

1.左移右移

1.题目描述

小蓝有一个长度为 NNN 的数组, 初始时从左到右依次是 1,2,3,…N1,2,3, \ldots N1,2,3,…N 。

之后小蓝对这个数组进行了 MMM 次操作, 每次操作可能是以下 2 种之一:

  1. 左移 xxx, 即把 xxx 移动到最左边。

  2. 右移 xxx, 即把 xxx 移动到最右边。

请你回答经过 MMM 次操作之后, 数组从左到右每个数是多少?

2.输入格式

第一行包含 2 个整数, NNN 和 MMM 。以下 MMM 行每行一个操作, 其中 “LxLxLx "表示左移 xxx ,"RxRxRx "表示右移 xxx 。

3.输出格式

输出 NNN 个数, 代表操作后的数组。

4.样例输入

5 3
L 3
L 2
R 1

5.样例输出

2 3 4 5 1

6.数据范围

1≤N,M≤200000,1≤x≤N.1≤N,M≤200000,1≤x≤N.1≤N,M≤200000,1≤x≤N.

6.原题链接

左移右移

2.解题思路

  题目的含义非常简单,如果按照朴素的方式遍历寻找 xxx,然后直接进行插入操作,在nnn的级别在2e52e52e5的范围这时间复杂度显然是不可接受的。想要解决此题我们需要思考两个点:

  1. 如何高效地进行插入和删除操作
  2. 如何快速地找到某个点所在的位置

  对于第一点,我们应该快速地想到链表这个数据结构,由于题目需要在左端点和右端点都进行插入操作,所以我们应该联想到 双链表 。它可以在O(1)O(1)O(1)的时间范围内对元素进行插入和删除,这显然是我们需要的数据结构。
  当然,双链表并不支持高效地查找,所以我们如何快速找到 xxx 的位置呢?这时候我们应该联想到 哈希表,因为我们需要手动实现双链表,所以每个链表结点都对应一个值,同时它也是一个对象,我们可以使用哈希表,以值为keykeykey,以这个链表结点对象为valuevaluevalue。这样我们就可以快速获得这个结点,然后再进行常规的双链表插入删除操作。

3.Ac_code

import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.util.*;public class Main {static Map map=new HashMap<>();static PrintWriter out=new PrintWriter(new OutputStreamWriter(System.out));public static void main(String[] args) {Scanner sc=new Scanner(System.in);int n=sc.nextInt();int m=sc.nextInt();//双链表的头结点和尾结点Node head=new Node(-1,null,null);Node last=new Node(-1,null,null);Node pre=head;//构建双链表for (int i = 1; i <=n; i++) {pre.next=new Node(i,pre,null);pre=pre.next;map.put(i,pre);}last.pre=pre;pre.next=last;for (int i = 0; i < m; i++) {char c=sc.next().charAt(0);int x=sc.nextInt();//先将x对应的结点在双链表中删除Node node=map.get(x);node.pre.next=node.next;node.next.pre=node.pre;if (c=='L'){//将其插入到左端点node.next=head.next;head.next.pre=node;head.next=node;node.pre=head;}else{//将其插入到右端点node.pre=last.pre;last.pre.next=node;node.next=last;last.pre=node;}}pre=head.next;while (pre!=last){out.print(pre.v+" ");pre=pre.next;}out.flush();}static class Node{int v;Node pre;Node next;public Node(int v, Node pre, Node next) {this.v = v;this.pre = pre;this.next = next;}}
}

相关内容

热门资讯

秤人添岁立夏忙,青瓷蛋雕绘新光 转自:上观新闻原标题:《【AI绘·二十四节气中的非遗】秤人添岁立夏忙,青瓷蛋雕绘新光》栏目主编:张陌...
乘船时要注意哪些事项?意外落水... 来源:央视新闻客户端 2025年05月04日下午,贵州省黔西市新仁苗族乡六冲河东风库区附近发生载人游...
工业和信息化部:加强通用大模型... 来源:新华社  记者近日从工业和信息化部获悉,下一步将加强通用大模型和行业大模型研发布局,加快建设工...
小观看天丨山洪+地灾预警,返程... 气象万千,小观看天!小伙伴们,早上好!今天是5月5日,星期一。今天迎来立夏节气,也是“五一”假期最后...
两人被捕 事故最终原因仍在确认... 当地时间5月4日,伊朗沙希德拉贾伊港口事故调查委员会公布了最新事故调查报告。报告指出,根据此前的初步...
市场消息:特朗普官员正探索挑战...   据报道,美国总统特朗普政府的官员正在探索挑战非营利组织免税地位的方法。媒体援引熟悉内情的人士的话...
反导系统未能拦截胡塞武装导弹,... 当地时间5月4日,以色列空军对当天胡塞武装向本-古里安机场发射导弹一事进行了调查,初步结果显示拦截失...
立夏节气预警大数据报告:雷电预... 今天(5月5日),我国进入夏季的第一个节气——立夏。这个时节,象征着春天的告别与夏日的开启,气温逐步...
加开列车! 转自:西安发布今天是2025年5月5日星期一(农历四月初八)今日立夏天气预报5日:多云,有浮尘或扬沙...
伊利集团张轶鹏:品质是伊利的最...   由Hehson财经主办的“第十届巴菲特股东大会中美投资人酒会”于美国当地时间5月3日在美国内布拉...
伊利集团张轶鹏:近两年乳企普遍...   由Hehson财经主办的“第十届巴菲特股东大会中美投资人酒会”于美国当地时间5月3日在美国内布拉...
迎难而上再捧苏杯 国羽展现强大... 转自:中国体育报5月4日,在厦门奥林匹克体育中心凤凰体育馆,中国羽毛球队如愿第14次捧起苏迪曼杯,大...
投资前瞻:周四聚焦美联储议息结...   来源:Wind万得  // 市场要闻 //  1、重磅宏观数据公布  5月7日,国家统计局将发...
今日立夏!风暖昼长,万物逐渐繁... 转自:北京日报客户端来源:北京日报客户端记者:胡德成流程编辑:U072
刘文萍到巨鹿县、隆尧县调研检查 转自:邢台网加快高端化智能化绿色化转型 持续塑造产业集群新动能新优势本报讯(记者谢霄凌 通讯员杨佳希...
俄称打击乌多目标,乌称袭击俄防... 俄罗斯国防部5月4日通报称,过去一天,俄军在苏梅、哈尔科夫、顿涅茨克、扎波罗热、赫尔松等方向打击乌军...
华安基金十年老将李欣离职!曾创...   又有资深基金经理官宣离职。  近日,华安基金发布公告,基金经理李欣因个人原因即将离任,新任基金经...
迎难而上再捧苏杯 国羽展现强... 5月4日,在厦门奥林匹克体育中心凤凰体育馆,中国羽毛球队如愿第14次捧起苏迪曼杯,大家激情庆祝这来之...
中国金茂,营收大增、利润下滑,...   来源:基本面力场  中国金茂(0817.HK)是力场君一只在关注的一只房地产股,也是力场君最喜欢...
河北滦平:雨后清晨金山岭长城云... 转自:北京日报客户端5月5日立夏节气,河北省承德市滦平县金山岭长城,迎来降雨天气。雨后清晨,云雾缭绕...