保姆级别的代码分享,虽然不是很简洁。
刚开始思路根本不清晰,看了大佬们的解法自己重构了一个,几番调整总算全部通过,分享一下。
n<5的情况比较简单,只用确定光标位置,没有翻页操作,不做分析。
n>4的情况分析如下:
- 问题点:如果确定当前页面的 4 首歌-------只需要确定当前页面某一首歌的索引位置,就能确定整个页面的四首歌
- 问题点:如何确定光标位置--------光标始终在显示页面的某一首歌上,因此其取值范围可固定为:1,2,3,4
- 问题点:Up 操作在什么位置特殊--------当光标位于页面第1首歌时,Up操作会刷新页面歌曲,实现一般翻页;当显示1~4首歌且光标位于1时,Up操作实现特殊翻页,页面歌曲变为显示 n-3~ n 首歌,光标位置位置变为4
- 问题点:Down 操作在什么位置特殊--------当光标位于页面第4首歌时,Down操作会刷新页面歌曲,实现一般翻页;当显示 n-3~ n 首歌且光标位于4时,Down操作实现特殊翻页,页面歌曲变为显示 1~4 首歌,光标位置位置变为1
- 其他:当光标不处于以上情况时,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