這是我的Minecraft mod算法。出於某種原因,似乎rand.nextInt(1);
只返回1。爲什麼?Random.nextInt(1);只返回1
public void generate(){
Random rand = new Random();
Arrays.fill(wc,null);
int c = generateCat();//Generates a int of 1-16 randomly
int i = 0;
int xi = 0;
int x = getCoordX();
int y = getCoordY();
int maxc = 0;
boolean d1 = true;
boolean d2 = false;
boolean d3 = false;
boolean d4 = false;
boolean loop = true;
wc[0] = new WeatherChunk(world,x,y,c);//Here the starting object is generated
x=x-1;
if(rand.nextInt(1)==1){//Here the c value (is supposed to have a 50% chance of reducing) But it never does EVER!?
c=getHNChunkCat(x,y);
c--;
wc[1] = new WeatherChunk(world,x,y,c);//Here the c value (is supposed to have a 50% chance of reducing) But it never does EVER!?
}else{
c=getHNChunkCat(x,y);
wc[1] = new WeatherChunk(world,x,y,c);
}
x=x+2;
if(rand.nextInt(1)==1){
c=getHNChunkCat(x,y);
c--;
wc[2] = new WeatherChunk(world,x,y,c);
}else{
c=getHNChunkCat(x,y);
wc[2] = new WeatherChunk(world,x,y,c);
}
x=x-1;
y++;
if(rand.nextInt(1)==1){
c=getHNChunkCat(x,y);
c--;
wc[3] = new WeatherChunk(world,x,y,c);
}else{
c=getHNChunkCat(x,y);
wc[3] = new WeatherChunk(world,x,y,c);
}
y=y-2;
if(rand.nextInt(1)==1){
c=getHNChunkCat(x,y);
c--;
wc[4] = new WeatherChunk(world,x,y,c);
}else{
c=getHNChunkCat(x,y);
wc[4] = new WeatherChunk(world,x,y,c);
}
y=wc[0].coordY;
x=wc[0].coordX-2;
i=5;
while(loop){
d1=true;
while(d1){
if(chunkExists(x+1,y)){
if(getHNChunkCat(x,y)>maxc)maxc=getHNChunkCat(x,y);
if(rand.nextInt(1)==1){
c=getHNChunkCat(x,y);
c--;
wc[i] = new WeatherChunk(world,x,y,c);
}else{
c=getHNChunkCat(x,y);
wc[i] = new WeatherChunk(world,x,y,c);
}
x++;
y++;
i++;
}else{
d1=false;
}
}
d2=true;
while(d2){
if(chunkExists(x,y-1)){
if(getHNChunkCat(x,y)>maxc)maxc=getHNChunkCat(x,y);
if(rand.nextInt(1)==1){
c=getHNChunkCat(x,y);
c--;
wc[i] = new WeatherChunk(world,x,y,c);
}else{
c=getHNChunkCat(x,y);
wc[i] = new WeatherChunk(world,x,y,c);
}
x++;
y--;
i++;
}else{
d2=false;
}
}
d3=true;
while(d3){
if(chunkExists(x-1,y)){
if(getHNChunkCat(x,y)>maxc)maxc=getHNChunkCat(x,y);
if(rand.nextInt(1)==1){
c=getHNChunkCat(x,y);
c--;
wc[i] = new WeatherChunk(world,x,y,c);
}else{
c=getHNChunkCat(x,y);
wc[i] = new WeatherChunk(world,x,y,c);
}
x--;
y--;
i++;
}else{
d3=false;
}
}
d4=true;
while(d4){
if(chunkExists(x-1,y)){
if(getHNChunkCat(x,y)>maxc)maxc=getHNChunkCat(x,y);
if(rand.nextInt(1)==1){
c=getHNChunkCat(x,y);
c--;
wc[i] = new WeatherChunk(world,x,y,c);
}else{
c=getHNChunkCat(x,y);
wc[i] = new WeatherChunk(world,x,y,c);
}
x--;
y++;
i++;
if(chunkExists(x,y)){
d4=false;
break;
}
}else{
d4=false;
}
}
y=wc[0].coordY;
x=wc[0].coordX;
xi=0;
while(true){
if(!chunkExists(x-xi,y)){
x=x-xi;
break;
}else{
xi++;
}
}
if(maxc==0){
loop=false;
}
}
cleanChunks();
WEATHER.addChunkArray(wc2);
}
香港專業教育學院還試圖
wc[1] = new WeatherChunk(world,x,y,(getHNChunkCat()-rand.nextInt(1)));
'nextInt(x)'返回一個介於'0'和''***'獨佔***之間的'int'。 – clcto 2015-01-20 20:49:39
'nextInt'方法的參數是上面的參數。所以它是0到1之間的整數範圍。 – 2015-01-20 20:50:11
它只返回0,從不1 1 – njzk2 2015-01-20 20:50:15