zoukankan      html  css  js  c++  java
  • Java-模拟电梯运行

    结果:
    (数字代表要去的楼层,-1表示关门)
    这里写图片描述

    代码:

    package dianti;
    
    import java.util.ArrayList;
    import java.util.Collections;
    import java.util.List;
    import java.util.Scanner;
    
    public class Main {
    
        public static void main(String[] args) throws InterruptedException {
            int curr = 1;// 当前楼层
            List<Integer> up = new ArrayList<Integer>();// 上
            List<Integer> down = new ArrayList<Integer>();// 下
    
            int go = 0;//目标楼层
    
            while (true) {
                Scanner sc = new Scanner(System.in);
    
                while (go != -1) {
                    go = sc.nextInt();
                    if (go > curr && go != -1)
                        up.add(go);
                    if (go < curr && go != -1)
                        down.add(go);
                }
                up.sort(null);
                Collections.sort(down, Collections.reverseOrder());
                for (int i = 0; i < up.size(); i++) {
                    curr = runUp(curr, up.get(i));
                }
                up.clear();
                for (int i = 0; i < down.size(); i++) {
                    curr = runDown(curr, down.get(i));
                }
                down.clear();
                go = curr;
            }
        }
    
        private static int runUp(int curr, int go) throws InterruptedException {
            int temp = curr;
            for (int i = 0; i < go - temp; i++) {
                System.out.println("-" + curr + "楼-");
                for (int j = 0; j < 3; j++) {
                    System.out.println("···");
                    Thread.sleep(500);
                }
    
                curr++;
            }
            if (curr == go) {
                System.err.println("到达" + go + "楼");
            }
            return curr;
        }
    
        private static int runDown(int curr, int go) throws InterruptedException {
            int temp = curr;
            for (int i = 0; i < temp - go; i++) {
                System.out.println("-" + curr + "楼-");
                for (int j = 0; j < 3; j++) {
                    System.out.println("···");
                    Thread.sleep(500);
                }
    
                curr--;
    
            }
            if (curr == go) {
                System.err.println("到达" + go + "楼");
            }
            return curr;
        }
    
    }
    
  • 相关阅读:
    001.Kubernetes简介
    DOCKER学习_018:Docker-Compose文件简介
    DOCKER学习_017:Docker-Compose介绍
    DOCKER学习_016:Docker镜像仓库和HARBOR的简单安装和管理
    DOCKER学习_015:Docker网络补充
    接口漏洞
    Shodan搜索引擎在信息搜集中的应用
    Google在情报搜集中的基础技巧
    数据抓包分析基础
    文件上传之图片木马的学习
  • 原文地址:https://www.cnblogs.com/cnsec/p/13286796.html
Copyright © 2011-2022 走看看