企业网站建设毕业设计论文,区块链 做网站,xxx网站建设策划书范文,网站建设需要学ps吗题目#xff1a; 注意题目中说明了数据时非递减的#xff0c;那么这样就存在二分性#xff0c;能够实现logn的复杂度。二分法每次只能取寻找特定的某一个值#xff0c;所以我们要分别求左端点和有端点。
分析第一组用例得到结果如下: 成功找到左端点8 由此可知#xff0…题目 注意题目中说明了数据时非递减的那么这样就存在二分性能够实现logn的复杂度。二分法每次只能取寻找特定的某一个值所以我们要分别求左端点和有端点。
分析第一组用例得到结果如下: 成功找到左端点8 由此可知用二分法去寻找左端端点的时候 若num[mid]target那么此时mid的左边包括自身的值都小于target,所以直接执行赋值操作left mid 1即可。 当num[mid] target的时候由于可能此时的mid已经是左端端点了。但是只是可能是左端点了也有可能不是左端点所以相等的情况就要和大于的情况合并起来操作执行right mid操作。 当num[mid]target的时候mid的右边包括自身都比target的值要大执行right mid具有合理性,不能执行right mid -1因为此时和等于合并起来了判断条件变成是num[mid] target在等于的情况下可能成为左端的端点。 图示* 上述就是找最左边的端点的基本思路了但是我们还有一些细节需要处理: 对于每次mid位置的取发: 1:mid left (right-left)/2 2:mid left (right-left 1)/2 有以上两种取法前后者在奇数的情况下相同但是在偶数的情况下就会有所不同。 偶数的情况下1会取到中间两个数的片左边的那一个2会取到中间两个数的偏右边那一个。
对于取左边端点来说:
到最终可能会有这么一种的情况: 所以在用二分法寻找左侧端点的时候应该要使用mid的第一种取法(mid left (right-left)/2 )。