从0开始学算法——第二十一天(链表练习)

写在开头的话

学习了今天的知识,让我们来做一道题目练练手吧。(题目是别的地方扒来的,参考答案是我自己写的,肯定不是最优解,有更好的方法欢迎评论区交流)

第一题------左移右移

参考答案

第一题参考答案(Python版)

python 复制代码
import sys

def solve():
    input = sys.stdin.read
    data = input().split()
    
    idx = 0
    N = int(data[idx]); idx += 1
    M = int(data[idx]); idx += 1
    
    # 使用双向链表,用数组模拟
    # left[i] 表示数字i左边的数字
    # right[i] 表示数字i右边的数字
    # 使用0作为左哨兵,N+1作为右哨兵
    left = [0] * (N + 2)
    right = [0] * (N + 2)
    
    # 初始化:1, 2, 3, ..., N
    for i in range(1, N + 1):
        left[i] = i - 1
        right[i] = i + 1
    
    # 设置哨兵
    left[0] = 0
    right[0] = 1
    left[N + 1] = N
    right[N + 1] = N + 1
    
    for _ in range(M):
        op = data[idx]; idx += 1
        x = int(data[idx]); idx += 1
        
        # 如果x已经在正确的位置,跳过(可选优化)
        if (op == 'L' and left[x] == 0) or (op == 'R' and right[x] == N + 1):
            continue
        
        # 将x从链表中移除
        l = left[x]
        r = right[x]
        right[l] = r
        left[r] = l
        
        if op == 'L':
            # 移动到最左边
            # 当前第一个元素是right[0]
            first = right[0]
            # 将x插入到0和first之间
            right[0] = x
            left[x] = 0
            right[x] = first
            left[first] = x
        else:  # 'R'
            # 移动到最右边
            # 当前最后一个元素是left[N+1]
            last = left[N + 1]
            # 将x插入到last和N+1之间
            left[N + 1] = x
            right[x] = N + 1
            left[x] = last
            right[last] = x
    
    # 输出结果
    result = []
    curr = right[0]
    while curr != N + 1:
        result.append(curr)
        curr = right[curr]
    
    print(' '.join(map(str, result)))

if __name__ == "__main__":
    solve()
相关推荐
徐小夕32 分钟前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法
通信小呆呆16 小时前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
H__Rick16 小时前
自动对焦学习-3
人工智能·学习·计算机视觉
benben04416 小时前
强化学习之DQN算法族(基于gymnasium开发)
算法
Daisy Lee16 小时前
量化学习-第1章-什么是量化金融
学习·金融·datawhale
Alsn8617 小时前
等待学习-学习目录:Docker 容器安全攻防
学习·安全·docker
YM52e17 小时前
买菜计算器小应用 - HarmonyOS ArkUI 开发实战-PC版本
学习·华为·harmonyos·鸿蒙·鸿蒙系统
何以解忧,唯有..17 小时前
Go语言循环语句详解:for、range与循环控制
开发语言·算法·golang
小雨下雨的雨17 小时前
HarmonyOS ArkUI训练营入门-组件掌握系列-Animation 动画效果实现-PC版本
学习·华为·harmonyos·鸿蒙