题解 | #MP3光标位置#

MP3光标位置

https://www.nowcoder.com/practice/eaf5b886bd6645dd9cfb5406f3753e15

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        int numsOfSongs = scan.nextInt();
        int[] arr = new int[numsOfSongs];
        for (int i = 0; i < numsOfSongs; i++) {
            arr[i] = i + 1;
        }
        String order = scan.next();
        char[] Order = order.toCharArray();
        int cur = 0;//表示当前所在位置的数组下标
        if (numsOfSongs <= 4) {
            for (int i = 0; i < Order.length; i++) {
                if (Order[i] == 'D') {
                    if (cur == numsOfSongs - 1) {
                        cur = 0;
                    } else {
                        cur++;
                    }
                } else {
                    if (cur == 0) {
                        cur = numsOfSongs - 1;
                    } else {
                        cur--;
                    }
                }
            }
            for (int i = 0; i < numsOfSongs; i++) {
                System.out.print(arr[i] + " ");
            }
            System.out.println();
        } else {
            int top = 0;//表示开始的时候屏幕顶部的位置的下标
            int bottom = 3;//表示开始的时候屏幕底部的位置的下标
            //由top和bottom维护一个窗口,大小始终是4
            for (int i = 0; i < Order.length; i++) {
                if (Order[i] == 'D') {
                    if (cur < bottom) {
                        cur++;
                    } else {
                        //此时就是cur == bottom
                        //cur并不会大于bottom,因为这个创就是我们自己维护边界的,cur只能在窗口内部活动
                        if (bottom < numsOfSongs - 1) {
                            bottom++;
                            cur++;
                            top++;
                        } else {
                            //此时就是bottom == numsOfSongs - 1,即来到了底部
                            cur = 0;
                            top = 0;
                            bottom = 3;
                        }
                    }
                } else { //指令不是'D'就是'U'
                    if (cur > top) {
                        cur--;
                    } else { //此时就是cur == top
                        if (top > 0) {
                            top--;
                            bottom--;
                            cur--;
                        } else { //否则就是top == 0了
                            top = numsOfSongs - 1 - 3;
                            bottom = numsOfSongs - 1;
                            cur = bottom;
                        }
                    }
                }
            }
            for (int i = top; i <= bottom; i++) {
                System.out.print(arr[i] + " ");
            }
            System.out.println();
        }
        System.out.println(cur + 1);

    }
}

全部评论

相关推荐

不愿透露姓名的神秘牛友
05-29 22:21
Offer1:小马智行,深圳,测试开发工程师,17.0k*16.0,Offer2:追觅科技,深圳,嵌入式工程师,18.0k*15.0,
嵌软狗都不学:各位base深圳的同事,作为也是并肩作战的一员,今天想站在管理视角,和大家开诚布公地聊一聊:从近几个月的上下班数据对比看来,我们发现一个明显的差异:深圳同事的在岗时间普遍比苏州同事短。很多深圳同事早上9点之后才到公司,晚上不到 20 点就下班了;而总部那边,20点半甚至 22 点后还有不少同事在办公室忙碌,特别是研发团队,加班更是常态。相信去过苏州的同事,对这种场景都不陌生。我很好奇,这是因为苏州工作任务太重还是咱们深圳同事效率真的高到能在更短时间内完成工作?MOVA在深圳成立分公司是为了吸引更优秀的人才贡献更多更高质的价值,公司管理层给我反馈的是深圳招到的多是行业的专家大拿,大部分都是薪资比苏州高的,而且我们办公的租金等也远高于苏州的..MOVA虽脱胎于强壮的集团母体不久,各业务板块尚未实现全面盈利,虽说公司管理层目光长远,不纠结当下的人才投入,但行业内的普遍标准是,员工创造的价值要达到公司雇佣成本的 15 倍以上。大家不妨自我审视一下,自己是否达到了这个标准?如果是抱着划水、按时打卡走人拿毛爷爷的心态那不适合来MOVA,那样过下去不但自己过得尴尬也会影响MOVA这个大船的攻城略地的速度.我并非鼓励大家盲目加班,而是倡导高效工作,拒绝无效忙碌,不要让项目进度因低效受影响,也别把精力浪费在和苏州同事拼打卡时长上,提倡更高的人效比;考虑到两地地域和交通差异,相信大家会找最适合自己发挥的工作方式(比如按时下班后1小时到家晚饭后继续未竟工作等..)大家在遵守公司规章的情况下尽情地体现自己的能力价值,为MOV!和深圳公司争光我们在这边才能更安心更有信心的工作下去;请客BU长、名部门长、项目管理和各业务单元负责人,全面梳理团队情况,及时评估成员工作负荷与成果质量,坚决清退划水害虫痕疫,践行公司价值观,相互监督,防止管理漏洞及渎职。感谢人家的理解,也请人家多担待我的直言不讳……
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务