华为机试-HJ64 MP3光标位置
作者:互联网
哒嗒~这是我博客的第一篇随笔,加油加油!
今天下午在牛客网刷oj题,想把学习记录保存起来方便后续学习,因此使用博客记录一下。
牛客网题目链接:https://www.nowcoder.com/practice/eaf5b886bd6645dd9cfb5406f3753e15
描述
MP3 Player因为屏幕较小,显示歌曲列表的时候每屏只能显示几首歌曲,用户要通过上下键才能浏览所有的歌曲。为了简化处理,假设每屏只能显示4首歌曲,光标初始的位置为第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