| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 881 人关注过本帖
标题:《tingking in java》学习中遇到障碍了,特来咨询
只看楼主 加入收藏
绿菜油小苦工
Rank: 1
等 级:新手上路
帖 子:30
专家分:0
注 册:2006-10-1
收藏
 问题点数:0 回复次数:3 
《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 障碍 咨询 学习 
2007-04-16 14:05
绿菜油小苦工
Rank: 1
等 级:新手上路
帖 子:30
专家分:0
注 册:2006-10-1
收藏
得分:0 
没人?

java 学习群 38859633 欢迎大家加入
2007-04-16 15:20
zz8386
Rank: 1
等 级:新手上路
帖 子:18
专家分:0
注 册:2006-10-4
收藏
得分:0 
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;


}

2007-04-16 15:51
angeloc
Rank: 7Rank: 7Rank: 7
等 级:贵宾
威 望:36
帖 子:1353
专家分:0
注 册:2006-11-21
收藏
得分:0 
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的长度加一,应该是为了防止数组越界吧!

老牛明知夕阳晚,不用扬鞭自奋蹄; Angelo\'s BLOG
2007-04-16 15:52
快速回复:《tingking in java》学习中遇到障碍了,特来咨询
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.027823 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved