当前位置: 代码迷 >> Java相关 >> 《tingking in java》学习中遇到障碍了,特来咨询
  详细解决方案

《tingking in java》学习中遇到障碍了,特来咨询

热度:150   发布时间:2007-04-16 14:05:41.0
《tingking in java》学习中遇到障碍了,特来咨询

//《thinking in java》中的一个例题,里面红色部分我还没还明白
//谁给我解释一下?
//程序大概就是给冰激凌调处20种味道的样子;
package myPakage;

public class ReturnStringArray {
static String[] flav=
{
"chocolate","strawberry",
"vanilla fudge swirl","mint chip",
"mocha almond fudge","rum raisin",
"praline cream","mud pie"
};

static String[] flavorSet(int n)
{
n=Math.abs(n)%(flav.length+1);//这啥意思啊
String[] results=new String[n];
boolean[] picked=new boolean[flav.length];

for(int i=0;i<n;i++)
{
int t;

do
t=(int)(Math.random()*flav.length);
while(picked[t]);

results[i]=flav[t];
picked[t]=true;
}

return results;


}

public static void main(String[] args)
{
for(int i=0;i<20;i++)
{
System.out.println("flavorSet("+i+")=");
String[] f1=flavorSet(flav.length);

for(int j=0;j<f1.length;j++)
{
System.out.println("\t"+f1[j]);
}
}
}

}

搜索更多相关的解决方案: java  tingking  障碍  咨询  学习  

----------------解决方案--------------------------------------------------------
没人?
----------------解决方案--------------------------------------------------------
static String[] flavorSet(int n)
{
n=Math.abs(n)%(flav.length+1);//  使n不超过flav的长度
String[] results=new String[n];
boolean[] picked=new boolean[flav.length];
//从flav中取出 n个不重复的元素 
for(int i=0;i<n;i++)
{
int t;

do
t=(int)(Math.random()*flav.length);
while(picked[t]);

results[i]=flav[t];
picked[t]=true;
}

return results;


}


----------------解决方案--------------------------------------------------------
n=Math.abs(n)%(flav.length+1);//这啥意思啊

求模运算,一个小的数和一个大的数求模得到的值是大的数,比如4%8=8,5%8=8
如果大的数和小的数求模得到的是余数,比如8%4=0,8%5=3

所以这个n=Math.abs(n)%(flav.length+1)根据下面传的值得到的就是flav的长度加一,应该是为了防止数组越界吧!
----------------解决方案--------------------------------------------------------
  相关解决方案