您的位置:首页 > 职场人生

黑马程序员-折半查找及进制的转换

2014-05-09 11:16 204 查看
---------------------- <a href="http://edu.csdn.net"target="blank">ASP.Net+Unity开发</a>、<a href="http://edu.csdn.net"target="blank">.Net培训</a>、期待与您交流! ----------------------

折半查找
class Demo
{
public static void main(String[] args)
{
int[] arr ={1,3,5,7,9,11};
int index = halfSearch(arr,9);
System.out.println("index="+index);

}
public static int halfSearch(int[] arr, int key)
{
int min,max,mid;
min = 0;max = arr.length-1;mid = (min+max)/2;
while(arr[mid]!=key)
{
if(key>arr[mid])
min = mid+1;
else if(key<arr[mid])
max = mid -1;
mid = (min+max)/2;
if(min>max)
return -1;
}
return mid;
}
}

进制的转换
class Demo2
{
public static void main(String[] args)
{
toBinary(60);
System.out.println();
toOctal(60);
System.out.println();
toHex(60);
}
public static void toBinary(int num)
{
trans(num,1,1);
}
public static void toOctal(int num)
{
trans(num,7,3);
}
public static void toHex(int num)
{
trans(num,15,4);
}
public static void trans(int num, int base, int offset)
{
char[] ch={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
char[] arr= new char[32];
int pos = arr.length;
while(num!=0)
{
int temp = num & base;
arr[--pos] = ch[temp];
num=num>>>offset;
}
for(int x=pos; x<arr.length; x++)
{
System.out.print(arr[x]);
}
}
}

---------------------- <a href="http://edu.csdn.net"target="blank">ASP.Net+Unity开发</a>、<a href="http://edu.csdn.net"target="blank">.Net培训</a>、期待与您交流! ----------------------
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: