【华为机试064】MP3光标位置

题目描述:

MP3 Player因为屏幕较小,显示歌曲列表的时候每屏只能显示几首歌曲,用户要通过上下键才能浏览所有的歌曲。为了简化处理,假设每屏只能显示4首歌曲,光标初始的位置为第1首歌。

现在要实现通过上下键控制光标移动来浏览歌曲列表,控制逻辑如下:

  1. 歌曲总数<=4的时候,不需要翻页,只是挪动光标位置。

光标在第一首歌曲上时,按Up键光标挪到最后一首歌曲;光标在最后一首歌曲时,按Down键光标挪到第一首歌曲。

其他情况下用户按Up键,光标挪到上一首歌曲;用户按Down键,光标挪到下一首歌曲。

  2. 歌曲总数大于4的时候(以一共有10首歌为例):

特殊翻页:屏幕显示的是第一页(即显示第1 – 4首)时,光标在第一首歌曲上,用户按Up键后,屏幕要显示最后一页(即显示第7-10首歌),同时光标放到最后一首歌上。同样的,屏幕显示最后一页时,光标在最后一首歌曲上,用户按Down键,屏幕要显示第一页,光标挪到第一首歌上。

一般翻页:屏幕显示的不是第一页时,光标在当前屏幕显示的第一首歌曲时,用户按Up键后,屏幕从当前歌曲的上一首开始显示,光标也挪到上一首歌曲。光标当前屏幕的最后一首歌时的Down键处理也类似。

其他情况,不用翻页,只是挪动光标就行。

Java实现:

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        while (sc.hasNext()) {
            int total = Integer.parseInt(sc.nextLine());
            String opr = sc.nextLine();
            char[] chars = opr.toCharArray();
            int curIndex = 1;
            if (total <= 4) {
                for (int i = 0; i < chars.length; i++) {
                    if (chars[i] == 'U') {
                        if (curIndex == 1)
                            curIndex = total;
                        else
                            curIndex -= 1;
                    }else if (chars[i] == 'D') {
                        if (curIndex == 4)
                            curIndex = 1;
                        else
                            curIndex += 1;
                    }
                }
                for (int i = 1; i < total; i++) {
                    System.out.print(i + " ");
                }
                System.out.println(total);
                System.out.println(curIndex);
            }else {
                int[] curList = {1, 2, 3, 4};
                for (int i = 0; i < chars.length; i++) {
                    if (chars[i] == 'U') {
                        if (curList[0] == 1 && curIndex == 1) {
                            curList[3] = total;
                            curList[2] = total - 1;
                            curList[1] = total - 2;
                            curList[0] = total - 3;
                            curIndex = total;
                        } else if (curList[0] == curIndex){
                            curList[3] -= 1 ;
                            curList[2] -= 1;
                            curList[1] -= 1;
                            curList[0] -= 1;
                            curIndex -= 1;
                        } else {
                            curIndex -= 1;
                        }
                    }else if (chars[i] == 'D') {
                        if (curList[3] == total && curIndex == total) {
                            curList[3] = 4;
                            curList[2] = 3;
                            curList[1] = 2;
                            curList[0] = 1;
                            curIndex = 1;
                        } else if (curList[3] == curIndex) {
                            curList[3] += 1 ;
                            curList[2] += 1;
                            curList[1] += 1;
                            curList[0] += 1;
                            curIndex += 1;
                        } else {
                            curIndex += 1;
                        }

                    }
                }

                for (int i = 0; i < 3; i++)
                    System.out.print(curList[i] + " ");
                System.out.println(curList[3]);
                System.out.println(curIndex);
            }


        }
    }
}

关键点:

  • 按照题目描述的分类一次处理,curList数组代表当前页面上歌曲的编号,curIndex代表当前光标处歌曲的编号

猜你喜欢

转载自blog.csdn.net/heyiamcoming/article/details/81099129
mp3