其他分享
首页 > 其他分享> > 华为机试-HJ64 MP3光标位置

华为机试-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键处理也类似。

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

数据范围:命令长度1\le s\le 100\1≤s≤100 ,歌曲数量1\le n \le 150\1≤n≤150  进阶:时间复杂度: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 page = 0;
46             int startposition = 0;//页起始位置
47             if (num <= 4) { //只有一页的情况
48                 for (int m = 1; m <= num; m++) {
49                     if ( m < num) {
50                         System.out.print(m + " ");
51                     } else {
52                         System.out.println(m);
53                     }
54                 }
55                 System.out.println(position);
56             } else {
57                 //输出歌曲总数大于4的情况下,操作结束后的当前列表和光标位置
58                 startposition = position - offset;
59                 int listitem = 0;
60                 for (int n = 1; n <= 4; n++) {
61                     listitem = startposition + n - 1;
62                     if (n < 4) {
63                         System.out.print(listitem + " ");
64                     } else {
65                         System.out.println(listitem);
66                     }
67                 }
68                 System.out.println(position);
69 //                 System.out.println(offset);
70             }
71         }//while循环结束
72 
73     }
74 }

 

标签:int,挪到,HJ64,num,歌曲,MP3,机试,一首,光标
来源: https://www.cnblogs.com/hsw-CN/p/16444077.html