java常用算法
冒泡排序:
//降序 public static int[] bubbleSort(int[] array){ for(int i = 0; i < array.length; i++){ int curval = array[i]; for(int j = i - 1; j >= 0; j--){ int temp = array[j]; if(curval > temp){ array[j] = curval; array[j+1] = temp; } } } return array; }
//升序 public static int[] bubbleSort(int[] array){ for(int i = array.length - 1; i >= 0; i--){ int curval = array[i]; for(int j = i; j < array.length-1; j++){ int tempval = array[j+1]; if(tempval < curval){ array[j+1] = curval; array[j] = tempval; } } } return array; }
二分法查找
//降序 public static int binarySearch (int[] array, int search){ int start = 0; int end = array.length-1; int middle = array.length / 2; for(; start <= end; ){ middle = (start + end) / 2; int val = array[middle]; if(val == search){ return middle; }else if(val > search){ start = middle + 1; }else{ end = middle - 1; } } return -1; }
//升序 public static int binarySearch(int[] array, int search){ int start = 0; int end = array.length - 1; int middle = (start + end) / 2; for(;start <= end;){ middle = (start + end) / 2; int midval = array[middle]; if(midval > search){ end = middle - 1; }else if(midval < search){ start = middle + 1; }else{ return middle; } } return -1; }
调用
public static void main(String[] args){ int[] test = new int[]{1,200,164,29,298,188,34,52,287,100,33}; int[] bubres = bubbleSort(test); for(int i = 0; i < bubres.length; i++){ System.out.println(i + "*************" + bubres[i]); } System.out.println("-----*****" + binarySearch(bubres, 1)); }
扫描公众号,关注更多信息
---------------------------------------------------------------------------------我是分割线--------------------------------------------------------------------------to be a better me, talk is cheap show me the code
版权所有,转载请注明原文链接。
文中有不妥或者错误的地方还望指出,以免误人子弟。如果觉得本文对你有所帮助不妨【推荐】一下!如果你有更好的建议,可以给我留言讨论,共同进步!
再次感谢您耐心的读完本篇文章。
----------------------------------------------------------------------------------------------------------------------------------------------------------------------
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?