题目:
小朋友出操,按学号从小到大排成一列;
小明来迟了,请你给小明出个主意,让他尽快找到他应该排的位置
算法复杂度要求不高于nlog( n) ;学号为整数类型,队列规模< 10000;
输入描述
第一行:输入已排成队列的小朋友的学号(正整数),以","隔开.
第二行:小明学号
输出描述
输出一个数字,代表队列位置(从1开始)
示例1:
输入
93,95,97,100,102,123,155
110
输出
6
题解:
题目比较简单,但是算法复杂度要求不高于nlog(n),那么就直接用二分法就可以了
代码:
import java.util.Scanner;
public class FindPos {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String[] pos = sc.nextLine().split(",");
int[] posValue = new int[pos.length];
for (int i = 0; i < pos.length; i++) {
posValue[i] = Integer.valueOf(pos[i]);
}
int posInt = Integer.valueOf(sc.nextLine());
System.out.println(findPos(posValue,posInt)+1); // 注意这里要+1 输出位置是从1开始,不是从0开始
}
private static int findPos(int[] nums, int pos) {
int left = 0;
int right = nums.length - 1;
int mid = 0;
while (left <= right) {
mid = (left + right) / 2;
if (pos == nums[mid]) {
return mid;
} else if (pos > nums[mid]) {
left = mid + 1;
} else {
right = mid - 1;
}
}
return left;
}
}
验证:

文章介绍了一个编程题目,要求在按学号排列的队伍中,利用二分查找法在nlog(n)时间内找到小明的位置,展示了如何通过代码实现并给出示例。
200

被折叠的 条评论
为什么被折叠?



