找找第k个数在第几堆里
/**
* 找找第k个数在第几堆里,例如:
* int k = 25;
* int[] array = new int[]{10, 12, 14, 15};
* 答案是 3 .
*
* @param heaps
* @param k
* @return
*/
public static int whereAmI(int[] heaps, int k) {
if (null == heaps || 0 == heaps.length || 0 >= k) {
return -1;
}
int[] heapRecord = new int[heaps.length];
int sum = 0;
for (int i = 0; i < heaps.length; i++) {
sum += heaps[i];
heapRecord[i] = sum;
}
if (k > sum) {
return -1;
}
return 1 + whereAmI(heapRecord, 0, heaps.length - 1, k);
}
private static int whereAmI(int[] heapRecord, int start, int end, int k) {
if (start >= end) {
return start;
}
int mid = start + (end - start) / 2;
if (heapRecord[mid] == k) {
return mid;
}
if (heapRecord[mid] < k) {
return whereAmI(heapRecord, mid + 1, end, k);
}
return whereAmI(heapRecord, start, mid - 1, k);
}

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
-
上一篇
泛型希尔排序
/** * 希尔排序 * * @param array * @param <C> */ public static <C extends Comparable> void sort(C[] array) { if (null == array || 1 >= array.length) { return; } // 奇数补1,偶数不补 int skip = array.length / 2 + (array.length % 2 == 1 ? 1 : 0); while (skip >= 1) { for (int i = 0; i + skip < array.length; i++) { cas(array, i, i + skip); } skip /= 2; } } /** * 比较/交换值 * * @param array * @param a * @param b * @param <C> */ @SuppressWarnings("unchecked") private static <C extends Com...
-
下一篇
Golang 入门系列(二)学习Go语言需要注意的坑
上一章节我们已经了解了 Go 环境的配置,不了解的,请查看前面的文章 https://www.cnblogs.com/zhangweizhong/p/9459945.html,本章节我们将学习 Go 语言的基础语法中需要注意的点。 GO语言基础语法 go 的基础语法,我这里就不细说了,大家可以查看这个文章,学习Go 详细的语法:http://www.runoob.com/go/go-basic-syntax.html 最好是对照上面的例子,一个一个敲出来,这样效果最好。 下面是一个Go 程序的基本结构,包含(包声明,引入包,函数等) package main // 定义包名,package main表示一个可独立执行的程序,每个 Go 应用程序都包含一个名为 main 的包。 import "fmt" // 导入需要使用的包(的函数,或其他元素) func main() { // 程序的入口函数。main 函数是每一个可执行程序所必须包含的,一般来说都是在启动后第一个执行的函数。 fmt.Println("Hello, World!") } GO语言注意的坑 不管学啥,刚开始都会遇...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2整合Redis,开启缓存,提高访问速度
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- SpringBoot2初体验,简单认识spring boot2并且搭建基础工程
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- Dcoker安装(在线仓库),最新的服务器搭配容器使用
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- SpringBoot2全家桶,快速入门学习开发网站教程
- CentOS7,8上快速安装Gitea,搭建Git服务器