(如需要牛客网的java面经电子版本以及其他学习视频,可以加个关注,私信我,免费分享)
有一个数组a[N]顺序存放0~N-1,要求每隔两个数删掉一个数,到末尾时循环至开头继续进行,求最后一个被删掉的数的原始下标位置。以8个数(N=7)为例:{0,1,2,3,4,5,6,7},0->1->2(删除)->3->4->5(删除)->6->7->0(删除),如此循环直到最后一个数被删除。
解题思路:
使用队列;首先将数组里面的元素全部放到队列中,在队列长度不等于1的前提下进行循环操作:定义一个计数器count,每一次把队首元素添加到队尾,出一次,count++一下,当count为2时,直接将队首元素出队即可。最后剩下的一个元素就是最后删除的一个元素。
代码实现:
import java.util.LinkedList;
import java.util.Queue;
import java.util.Scanner;
public class Demo3 {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
while (scanner.hasNext()) {
int n = scanner.nextInt();
int[] arr = new int[n];
for (int i = 0; i < arr.length; i++) {
arr[i] = i;
}
System.out.println(delete(arr));
}
scanner.close();
}
public static int delete (int[] arr) {
Queue<Integer> queue = new LinkedList<>();
for (int i = 0; i < arr.length; i++) {
queue.add(arr[i]);
}
while (queue.size() != 1) {
int count = 0;
while (count != 2) {
queue.add(queue.peek());
queue.poll();
count++;
}
queue.poll();
}
return queue.element();
}
}