答复: 一道算法题,百思不得其解,求指导[非降序列找目标项,二分法变体]

本文介绍了如何通过随机数生成和二分搜索算法实现复杂度优化,具体包括初始化数组、生成随机数并调整元素值、进行二分搜索查找目标元素及其性能分析。
正确解看此链接
http://www.cnblogs.com/sunyongyue/archive/2010/12/04/1896675.html
这个条件粗看起来不是很靠谱,事实上却很好用

代码实现如下,

import java.util.Arrays;

public class AiEqualsISearcher {
private static int ARR_LENGTH = 100;
private int[] numArr = new int[ARR_LENGTH];
private int stepCount = 0;

private void init() {
int targetElement = (int) (Math.random() * (ARR_LENGTH - 1));
numArr[targetElement] = targetElement;
int num = targetElement - 1;
while (num >= 0) {
int tmp = (int) (Math.random() * 3);
numArr[num] = numArr[num + 1] - tmp;
if (numArr[num] == num) {
numArr[num] = num - 1;
}
num--;
}
for (int i = targetElement + 1; i < ARR_LENGTH; i++) {
int tmp = (int) (Math.random() * 5);
numArr[i] = numArr[i - 1] + tmp;
if (numArr[i] == i) {
numArr[i] = i + 1;
}
}
System.out.println("the num arr init as " + Arrays.toString(numArr));
System.out.println("the target index is " + targetElement);
}

private int search(int start, int end) {
System.out.println("check a[" + start + "," + end + "]");
stepCount++;
int middle = (start + end) / 2;
if (numArr[middle] == middle) {
return middle;
}
if (start >= end) {
return -1;
}
if (end >= numArr[middle]) { // && numArr[end] >= middle
int result = search(middle + 1, end);
if (result != -1) {
return result;
} else {
return search(start, middle - 1);
}
} else {
System.out
.println("a[" + middle + "," + end + "] no need to check");
return search(start, middle - 1);
}
}

public static void main(String[] args) {
AiEqualsISearcher searchAi = new AiEqualsISearcher();
searchAi.init();
System.out.println("\nstart to search...");
int i = searchAi.search(0, AiEqualsISearcher.ARR_LENGTH - 1);
if (i >= 0) {
System.out.println("find a[" + i + "]=" + i + " with "
+ searchAi.stepCount + " steps ");
} else {
System.out.println("can't find the element");
}
}
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值