从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()
相关推荐
Slow菜鸟2 小时前
AI学习篇(五) | awesome-design-md 使用说明
人工智能·学习
超级码力6662 小时前
【Latex文件架构】Latex文件架构模板
算法·数学建模·信息可视化
ZC跨境爬虫2 小时前
跟着 MDN 学 HTML day_9:(信件语义标记)
前端·css·笔记·ui·html
穿条秋裤到处跑2 小时前
每日一道leetcode(2026.04.29):二维网格图中探测环
算法·leetcode·职场和发展
Merlos_wind2 小时前
HashMap详解
算法·哈希算法·散列表
狐狐生风2 小时前
LangChain 向量存储:Chroma、FAISS
人工智能·python·学习·langchain·faiss·agentai
狐狐生风3 小时前
LangChain RAG 基础
人工智能·python·学习·langchain·rag·agentai
汉克老师3 小时前
GESP2025年3月认证C++五级( 第三部分编程题(1、平均分配))
c++·算法·贪心算法·排序·gesp5级·gesp五级
努力努力再努力FFF5 小时前
医生对AI辅助诊断感兴趣,作为临床人员该怎么了解和学习?
人工智能·学习
OBiO20135 小时前
Cell | 突破AAV载体容量限制!路中华/姜玉武/刘太安团队开发AAVLINK系统实现大基因递送
笔记