黑马程序员技术交流社区
标题:
折半法中的应用
[打印本页]
作者:
徐宏波
时间:
2012-3-15 16:03
标题:
折半法中的应用
/*
需求:将一个数插入一个有序数组中,并不打乱顺序.int[] arr={3,5,9,10,11,16,18},要插入的数为12,
思路及步骤:
利用折半法查找数组中是否有这个数及其位置,如没有,找到最小角标的值,并将数插入.
1.定义变量,int max,min,mid;mid=(min+max)>>1;
*/
class ArrayDemoa
{
public static int halfsearch(int[] arr,int key )
{
int max=arr.length-1,min=0,mid;
while(min<=max)
{
mid=(max+min)>>1;
if(key>arr[mid])
min=mid+1;
else if(key<arr[mid])
max=mid-1;
else
return mid;
}
return min;
}
public static void main(String[] args)
{
int[] arr={3,5,9,10,11,16,18};int key=12;
int Index=halfsearch(arr,key);
System.out.println("Index="+Index+";");
}
}
上边这个是我写的啦,是看完毕老师的视频写的,但是我想的是,在while里边用的是if语句,但我觉得好像用switch语句更好呢,switch的适用范围:也能满足啊,,自己写来的,但没弄对;谁能帮我解释下,到底能不能换成switch语句,,如果能换,帮我写一个让我学习一下.不能的话,为什么?谢谢
作者:
彭卫红
时间:
2012-3-15 17:07
提示:
作者被禁止或删除 内容自动屏蔽
作者:
徐宏波
时间:
2012-3-15 18:23
彭卫红 发表于 2012-3-15 17:07
switch语句的语法格式为:
switch(表达式){
:dizzy:我懂了,,记得毕老师说过的,,对结果为boolean型的判断,要用if的....不能用switch.....又回去看了一遍视频,,懂了,呵呵,
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2