黑马程序员技术交流社区

标题: 帮我解释一下这几个if语句 [打印本页]

作者: 李深山    时间: 2012-3-19 20:53
标题: 帮我解释一下这几个if语句
int array[]={0,34,67,90,21,-9,98,1000,-78};
System.out.println(new CTest().findMax(array, 0));
}
public int findMax(int array[],int index)
{
if(array==null || array.length==0)
{
return 0;
}
int max=array[0];
if(index<array.length-1)
{
max=findMax(array,index+1); //帮我解释一下这几个if语句。详细点啊
}
if(max<array[index])
max= array[index];
return max;
作者: 乔玉吉    时间: 2012-3-19 21:28
代码不完整 没法回答
作者: 程洪    时间: 2012-3-19 21:45
本帖最后由 程洪 于 2012-3-19 21:48 编辑

                int array[]={0,34,67,90,21,-9,98,1000,-78};
                System.out.println(new CTest().findMax(array, 0));
                }
                public int findMax(int array[],int index)
                {
                if(array==null || array.length==0)        //如果array 等于 null 或者 array数组长度 等于0;
                {
                return 0;                                                        //返回0
                }
                int max=array[0];                       
                if(index<array.length-1)                        //如果传入的参数 index小于 数组的长度-1
                {
                        max=findMax(array,index+1);                //最大
                }
                if(max<array[index])                                //如果max这个数 小于 数组的传入的角标的这个数array[index]
                max= array[index];                                        //那么 array[index] 就是最大的数
                return max;


由于代码补完善 大概就分析出这个事情!
作者: 魏群    时间: 2012-3-19 21:54
本程序中每次递归的时候都把 array[0]设为最大值。
首先执行findMax(array, 0);传进方法中的index=0 这时
if(index<array.length-1)
比较传进来的index时候小于数组的长度-1;也就是0<数组的长度-1 成立的话在一次执行findMax(int arra[],intindex)这时的index变为1。
在findMax(array,1)的方法中
if(index<array.length-1) 还是成立,那么就在执行findMax(int array[],int index)它这时index=2,依次类推直到最有一次findMax(int arra[],intindex)取得返回值
下面是最后一次执行findMax(int array[],int index)的情形
当index=7的时候最后一次执行public int findMax(int array[],int index)方法,这时方法中index=8。当index=8的时候if(index<array.length-1)里的代码块就不执行了。
开始执行
if(max<array[index])
  max= array[index];
return max;
取出最大值,也就是比较array[0]和array[8]其中的最大值。并返回给上一次调用此方法的方法。
上一次调用此方法的方法在执行
if(max<array[index])
  max= array[index];
return max;
取出最大值返回给调用它的方法,依次类推回第一次执行public int findMax(int array[],int index)的时候最后返回整个数组的最大值。
可能写的有点啰嗦希望你能明白。
作者: 李深山    时间: 2012-3-19 22:03
谢谢,说的挺好的





欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2