以前工作过程中学习的过程中写了很多测试程序,上周acer本本硬盘坏了,换了个新硬盘,数据全部丢失了,很多有用的东西就这样没了,可惜的很。以后把工作和学习中的到的东西还是放到网上来比较好点。
最近,在论坛上看到有个人搞了个每日一题,觉得挺不错。最近在看数据结构,想想是否也可以来个每天看看数据结构。觉得那些东西虽然不是很难,但是若是坚持一段时间,量变必然会产生质变。而且每天花点时间在英语上,那么也会产生效果,背诵新概念的工程也该重启了,以前背了一段时间的,现在又忘了。
javaeye月刊上有一个关于24点算法的讨论,很多人也参入讨论,有人说看谁20行以内解决,似乎不可能,不过参入讨论给的代码都比我的要长很多,看来自己还不是太笨。数据机构不会每天都写,但是每天都会看点,过段时间把排序的多个方法总结下,希望09年有所提高。昨天写的个利用归并和递归来实现的排序,有些问题,在4个数的时候是正确的,多于四个数字的时候,有一个数字不正确,还没找到原因。先把学习的一个递归二分查找贴出来。
二分查找
int[] binary = {1,2,3,4,5,6,7,8,9}; int lower = 0; int upper = binary.length-1; int curIn; int searchNum = 6; while(true) { curIn = (upper + lower)/2; if(binary[curIn] == searchNum) { System.out.println(searchNum + "存在于数组的" + curIn + "位置"); return; }else if(upper < lower) { System.out.println(searchNum + "在数组中不存在"); return; }else{ if(binary[curIn]>searchNum) { upper = curIn - 1; }else if(binary[curIn]<searchNum) { lower = curIn + 1; } } }
二分查找的递归实现,属于分治算法。分治算法, 常常是一个方法,这个方法中包含两个对自身的递归调用,但是只有一个真的执行了。
static int[] binary = {1,2,3,4,5,6,7,8,9}; public static void main(String[] args) { int lower = 0; int upper = binary.length; int searchNum = 6; binarySearch(searchNum,lower,upper); } private static void binarySearch(int searchNum, int lower, int upper) { int curItem = (lower + upper)/2; if(binary[curItem] == searchNum) { System.out.println(searchNum + "在数组的" + curItem + "位置上"); }else if(lower>upper) { System.out.println("不存在该值"); } else { if(binary[curItem]>searchNum) { binarySearch(searchNum,lower,curItem-1); } if(binary[curItem]<searchNum) { binarySearch(searchNum,curItem+1,upper); } } }