保姆级别的代码分享,虽然不是很简洁。
刚开始思路根本不清晰,看了大佬们的解法自己重构了一个,几番调整总算全部通过,分享一下。
n<5的情况比较简单,只用确定光标位置,没有翻页操作,不做分析。
n>4的情况分析如下:
  1. 问题点:如果确定当前页面的 4 首歌-------只需要确定当前页面某一首歌的索引位置,就能确定整个页面的四首歌
  2. 问题点:如何确定光标位置--------光标始终在显示页面的某一首歌上,因此其取值范围可固定为:1,2,3,4
  3. 问题点:Up 操作在什么位置特殊--------当光标位于页面第1首歌时,Up操作会刷新页面歌曲,实现一般翻页;当显示1~4首歌且光标位于1时,Up操作实现特殊翻页,页面歌曲变为显示 n-3~ n 首歌,光标位置位置变为4
  4. 问题点:Down 操作在什么位置特殊--------当光标位于页面第4首歌时,Down操作会刷新页面歌曲,实现一般翻页;当显示 n-3~ n 首歌且光标位于4时,Down操作实现特殊翻页,页面歌曲变为显示 1~4 首歌,光标位置位置变为1
  5. 其他:当光标不处于以上情况时,Up 、Down 操作只会实现光标位置变化,当前页面的4首歌曲不会变化
按以上思路代码如下:
while True:  try:
        n = int(input())  # 储存歌曲总数
        s = input().strip() # 储存操作
        l = []
        for i in range(1, n+1): # 建立歌曲列表(非必要,我这里是为了统一输出,完全可以不用列表直接输出)
            l.append(i)
    # 关键变量
        f = 1    # f 用于指示当前页面第1首歌曲的索引位置,即应对问题 1
        p = 1    # p 用于指示当前页面光标所在位置,即应对问题 2 ,一页最多显示4首歌,所以 p 的取值范围在 1,2,3,4 之中

        if n < 5: # 第一种情况,歌曲总数最多一页,没有翻页操作,比较简单,实现方法很多,这里不做介绍
            for i in s:
                if i == 'U':
                    if p == 1:
                        p = n
                    else:
                        p -= 1
                if i == 'D':
                    if p == n:
                        p = 1
                    else:
                        p += 1
    # 第二种情况,歌曲总数多于一页,有翻页操作,详见代码注释
        else:
            for i in s:             # 依次遍历操作
                if i == 'U':                # 判断操作是否为 Up
                    if f == 1 and p == 1:    # 问题点3:特殊翻页处理;当且仅当,当前页面为歌曲1 2 3 4(f = 1)且光标位于位置 1(p = 1)时,从第一页翻到最后一页
                        f = n - 3                # 最后一页的4首歌为:n-3  n-2  n-1  n,因此 f = n-3
                        p = 4                    # 特殊翻页过后,光标直接指向当前页面最后一首歌,即 p = 4
                    elif p == 1:            #问题点3:一般翻页操作; 当光标位于当前页面第一首歌时,Up操作不会改变光标位置,即p=1不变,而向上翻页使得f = f-1
                        f -= 1
                    else:                    #问题点5:普通操作。当光标不在当前页面第一首歌时,Up操作只会改变光标位置(p = p-1),不会改变f
                        p -= 1
                if i == 'D':                # Down 操作同理,理解特殊翻页,一般翻页 f 和 p的取值即变化,即可进行              
                    if f == n-3 and p == 4:
                        f = 1
                        p = 1
                    elif p == 4:
                        f += 1
                    else:
                        p += 1

        for i in l[f-1:f+4-1]: # 输出当前页,列表索引从0开始,因此变量 f 需要减 1
            print(i,end=' ')
        print()
        print(f+p-1)
            
    except:
        break