算法笔记第一天(1)
2021/4/16 20:30:14
本文主要是介绍算法笔记第一天(1),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
1.实现数组拷贝
private static int[] copyArray(int[] a){ if(a == null || a.length == 0 ){ return null; } int[] b = new int[a.length]; for(int i = 0;i<a.length;i++){ b[i] = a[i]; } System.out.println(JSONObject.toJSONString(b)); return b; }
2.转换首尾顺序
private static int[] transferHeadToTail(int[] b){ if(b == null || b.length == 0){ return null; } int k = b.length/2; int[] t = new int[b.length]; for(int i = 0;i<k;i++){ int temp = b[i]; t[i] = b[b.length-i-1]; t[b.length-i-1] = temp; } return t; }
3.递归实现二分排序
private static int binsearch(int[] t,int data){ return digui(t,t.length,0,data); } private static int digui(int[] t,int high,int low,int data){ if(high<low){ System.out.println("没有此数据"); return 0; } int middle = low + (high-low)/2; if(data > t[middle]){ return digui(t,high,middle+1,data); }if(data<t[middle]){ return digui(t,middle-1,low,data); }else { return middle; } }
main方法:
public static void main(String[] args) { int[] b = {3,4,5,6,7,8,9,10,11,13,23,44,333}; System.out.println(JSONObject.toJSONString(copyArray(b))); System.out.println(JSONObject.toJSONString(transferHeadToTail(b))); System.out.println(binsearch(b,77)); }
这篇关于算法笔记第一天(1)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-15鸿蒙生态设备数量超8亿台
- 2024-05-13TiDB + ES:转转业财系统亿级数据存储优化实践
- 2024-05-09“2024鸿蒙零基础快速实战-仿抖音App开发(ArkTS版)”实战课程已上线
- 2024-05-09聊聊如何通过arthas-tunnel-server来远程管理所有需要arthas监控的应用
- 2024-05-09log4j2这么配就对了
- 2024-05-09nginx修改Content-Type
- 2024-05-09Redis多数据源,看这篇就够了
- 2024-05-09Google Chrome驱动程序 124.0.6367.62(正式版本)去哪下载?
- 2024-05-09有没有大佬知道这种数据应该怎么抓取呀?
- 2024-05-09这种运行结果里的10.100000001,怎么能最快改成10.1?