华为OD-D卷小明找位置

题目:小朋友出操,按学号从小到大排成一列;小明来迟了,请你给小明出个主意,让他尽快找到他应该排的位置。

算法复杂度要求不高于nLog(n);学号为整数类型,队列规模<=10000;

输入描述:

1、第一行:输入已排成队列的小朋友的学号(正整数),以","隔开;

例如:93 95 97 100 102 123 155

2、第二行:小明学号,如110;

输出描述:

输出一个数字,代表队列位置(从1开始)。

例如:6

题目解析:

本题本质上还是对二分查找,只不过已知要找的数不在队列当中而已:

需要注意:队列位置(从1开始)

java 复制代码
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
//        int[] nums = new int[]{93, 95, 97, 100, 102, 123, 155};
//        int target = 110;
        // 处理数据
        Scanner scanner = new Scanner(System.in);
        String string = scanner.nextLine();
        String[] numsStr = string.split(",");
        int[] nums = new int[numsStr.length];
        for (int i = 0; i < nums.length; i++) {
            nums[i] = Integer.parseInt(numsStr[i]);
        }
        int target = scanner.nextInt();

        // 二分查找
        int left = 0;
        int right = nums.length - 1;
        int mid;
        // 注意等号,避免漏掉查找的数
        while (left <= right) {
            // 代替 (right+left) / 2 ,可以避免 right+left 超过 int 范围,一般情况下不用考虑
            mid = left + (right - left) / 2;
            if (target == nums[mid]) {
                System.out.println(mid + 1);
                return;
            } else if (target < nums[mid]) {
                right = mid - 1;
            } else {
                left = mid + 1;
            }
        }
        // 需要注意队列位置从1开始
        System.out.println(left + 1);
    }
}
相关推荐
小鑫记得努力几秒前
Java类和对象(下篇)
java
binishuaio4 分钟前
Java 第11天 (git版本控制器基础用法)
java·开发语言·git
zz.YE6 分钟前
【Java SE】StringBuffer
java·开发语言
老友@6 分钟前
aspose如何获取PPT放映页“切换”的“持续时间”值
java·powerpoint·aspose
wrx繁星点点22 分钟前
状态模式(State Pattern)详解
java·开发语言·ui·设计模式·状态模式
王哈哈^_^24 分钟前
【数据集】【YOLO】【VOC】目标检测数据集,查找数据集,yolo目标检测算法详细实战训练步骤!
人工智能·深度学习·算法·yolo·目标检测·计算机视觉·pyqt
Upaaui24 分钟前
Aop+自定义注解实现数据字典映射
java
zzzgd81625 分钟前
easyexcel实现自定义的策略类, 最后追加错误提示列, 自适应列宽,自动合并重复单元格, 美化表头
java·excel·表格·easyexcel·导入导出
友善的鸡蛋26 分钟前
解决:使用EasyExcel导入Excel模板时出现数据导入不进去的问题
java·easyexcel·excel导入
星沁城26 分钟前
240. 搜索二维矩阵 II
java·线性代数·算法·leetcode·矩阵