ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

华为机试-HJ64 MP3光标位置

2022-07-04 19:00:39  阅读:157  来源: 互联网

标签:int 挪到 HJ64 num 歌曲 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

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有