华为OJ——MP3光标位置

题目描述

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

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

  • 1.歌曲总数<=4
      不需要翻页,只是挪动光标位置。光标在第一首歌曲上时,按Up键光标挪到最后一首歌曲;光标在最后一首歌曲时,按Down键光标挪到第一首歌曲。

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

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

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

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

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

输入描述:

  • 输入说明:

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

输出描述:

  • 输出说明

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

  • 示例1

    输入

      10
      UUUU
    输出

      7 8 9 10
      7

实现代码

  • 思路:

    按照题意的几种情况分析即可

package cn.c_shuang.demo61;

import java.util.Scanner;
/**
 * MP3光标位置
 * @author Cshuang
 *
 */
public class Main {
     public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        while (in.hasNextLine()){
            int n=in.nextInt();
            String s=in.next();
            if(n<4)
                less4(s,n);
            else
                more4(s,n);
        }
        in.close();
    }
    private static void more4(String s, int n) { 
        char[] ch = s.toCharArray();
        int begin = 1, cur = 1; // 起始序号,当前歌曲序号
         for (int i = 0; i < ch.length; i++) {
            if (begin==1 && cur == 1 && ch[i] == 'U') { // 光标在第一页 ,第一首歌曲上时,按Up键光标
                cur = n;
                begin = n-3;
            }else if (begin==n-3 && cur == n && ch[i] == 'D') { // 光标在最后一页,最后一首歌曲时,按Down键光标
                cur= 1;
                begin = 1;
            }else if (ch[i] == 'U' && begin==cur ) {  // 光标在非第一页,第一首歌曲时,按Up键后,从当前歌曲的上一首开始显示,光标也挪到上一首歌曲。
                cur --;
                begin--;
                continue;
            }else if (ch[i] == 'D' && begin+3==cur) {
                cur ++;
                begin++;
            }else if(ch[i] == 'U'){//若不满足上面条件,说明此时起始页begin不需变,只需要改变当前光标cur所在位置
                cur--;
            }else{
                cur++;
            }
        }
        System.out.println(begin + " " + (begin + 1) + " " + (begin + 2)+ " " + (begin + 3));
        System.out.println(cur);        
    }
    private static void less4(String s, int n) {
         char[] ch = s.toCharArray();
         int begin = 1, cur = 1; // 起始序号,当前歌曲序号
         for (int i = 0; i < ch.length; i++) {
             if (cur == 1 && ch[i] == 'U') // 光标在第一首歌曲上时,按Up键光标
                 cur = n;
             else if (cur == n && ch[i] == 'D') // 光标在最后一首歌曲时,按Down键光标
                 cur = 1;
             else{
                 if (ch[i] == 'U')
                     cur--;
                 else
                     cur++;
             }
         }
         for (int i = 0; i < n; i++) {
             if(i!=n-1)
                 System.out.print(begin+i+" ");
             else 
                 System.out.println(begin+i);
         }
         System.out.println(cur);
     }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值