华为机试-HJ64 MP3光标位置

哒嗒~这是我博客的第一篇随笔,加油加油!

今天下午在牛客网刷oj题,想把学习记录保存起来方便后续学习,因此使用博客记录一下。

牛客网题目链接:https://www.nowcoder.com/practice/eaf5b886bd6645dd9cfb5406f3753e15

 

描述

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

 

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

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

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

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

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

 

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

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

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

数据范围:命令长度1s100 ,歌曲数量1n150 
进阶:时间复杂度:O(n)\O(n) ,空间复杂度:O(n)\O(n) 

输入描述:

输入说明:
1 输入歌曲数量
2 输入命令 U或者D

输出描述:

输出说明
1 输出当前列表
2 输出当前选中歌曲

示例1

输入:
10
UUUU
输出:
7 8 9 10
7
 
代码:
 1 import java.util.Scanner;
 2 
 3 public class Main {
 4     public static void main(String[] args) {
 5         Scanner sc = new Scanner(System.in);
 6         while (sc.hasNext()) {
 7             int num = Integer.parseInt(sc.nextLine());
 8             String str = sc.nextLine();
 9 //             System.out.println("num: " + num);
10 //             System.out.println("str: " + str);
11             char[] ch = str.toCharArray();
12             int position = 1;//光标位置
13             int offset = 0;//标记光标在页内的偏移量(0-3),0-页内第一首 3-页内最后一首
14             //依次读取操作命令
15             for (int i = 0; i < ch.length; i++) {
16                 if (ch[i] == 'U') {
17                     if (num <= 4) {
18                         position = Math.max(1, position - 1); //不翻页,到顶了只能停在第一首
19                     } else {
20                         if (position == 1) { //光标在第一首
21                             position = num;//光标上移翻页至末尾
22                             offset = 3;//翻页后光标在末尾
23                         } else {
24                             position = position - 1;//光标正常上移
25                             offset = offset - 1 < 0 ? 0 : offset - 1; //光标在页内最顶上
26                         }
27                     }
28 //                     System.out.println(ch[i]+" position: "+position+" offset: "+offset);
29                 } else if (ch[i] == 'D') {
30                     if (num <= 4) {
31                         position = Math.min(num, position + 1); //不翻页,到列表末尾只能在第num首
32                     } else {
33                         if (position == num) { //光标在最后一首
34                             position = 1;//光标下移翻页至第一首
35                             offset = 0;
36                         } else {
37                             position = position + 1;//光标正常下移
38                             offset = offset + 1 > 3 ? 3 : offset + 1; //光标在页内最末尾
39                         }
40                     }
41 //                     System.out.println(ch[i]+" position: "+position+" offset: "+offset);
42                 }
43             }//for循环结束
44             //根据光标位置和页内偏移量找到所在页起始位置
45             int startposition = 0;//页起始位置
46             if (num <= 4) { //只有一页的情况
47                 for (int m = 1; m <= num; m++) {
48                     if ( m < num) {
49                         System.out.print(m + " ");
50                     } else {
51                         System.out.println(m);
52                     }
53                 }
54                 System.out.println(position);
55             } else {
56                 //输出歌曲总数大于4的情况下,操作结束后的当前列表和光标位置
57                 startposition = position - offset;
58                 int listitem = 0;
59                 for (int n = 1; n <= 4; n++) {
60                     listitem = startposition + n - 1;
61                     if (n < 4) {
62                         System.out.print(listitem + " ");
63                     } else {
64                         System.out.println(listitem);
65                     }
66                 }
67                 System.out.println(position);
68 //                 System.out.println(offset);
69             }
70         }//while循环结束
71 
72     }
73 }

 

posted @ 2022-07-04 18:54  小小米-Hwang  阅读(157)  评论(0)    收藏  举报