从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()
相关推荐
驱动探索者1 天前
linux mailbox 学习
linux·学习·算法
ringking1231 天前
autoware-1:安装环境cuda/cudnn/tensorRT库函数的判断
人工智能·算法·机器学习
进阶小白猿1 天前
Java技术八股学习Day33
java·开发语言·学习
收菜福星1 天前
当AI Agent成为大学标配:2026年学习模式的深层变革
人工智能·学习
蒟蒻的贤1 天前
yolo12结构学习
学习
大闲在人1 天前
8. 供应链与制造过程术语:产能
算法·制造·供应链管理·智能制造·工业工程
一只小小的芙厨1 天前
寒假集训笔记·以点为对象的树形DP
c++·算法
历程里程碑1 天前
普通数组----合并区间
java·数据结构·python·算法·leetcode·职场和发展·tornado
执风挽^1 天前
Python基础编程题2
开发语言·python·算法·visual studio code
●VON1 天前
CANN推理引擎:从云端到边缘的极致加速与部署实战
学习·react native