展开全部
像这种图形对称的由少变多再变少可以考虑绝对值控制。
打个比方:就像在一个数轴上,越接近中心则距离越短,然后过了中心后,就会离中心越来越远。代码如下,如果n是可输入的,你用IO输入流代替即可。
public static void main(String[] args){
int n = 5;//*号的行数
/*控制*号的数量,最小为1,最大为n,由绝对值计算出变化*/
int m = 1;
int space = (n + 1) / 2;//空格的最大值
int s = 1;//和上面同理
for(int i = 0; i < n; i++){
//控制空格输出
for(int j = 0; j < Math.abs(space-s); j++){
System.out.print(" ");
}
s++;
//控制*号输出
for(int k = 0; k < n - Math.abs(n - m); k++){
System.out.print("*");
}
m += 2;
System.out.println();
}
}
打个比方:就像在一个数轴上,越接近中心则距离越短,然后过了中心后,就会离中心越来越远。代码如下,如果n是可输入的,你用IO输入流代替即可。
public static void main(String[] args){
int n = 5;//*号的行数
/*控制*号的数量,最小为1,最大为n,由绝对值计算出变化*/
int m = 1;
int space = (n + 1) / 2;//空格的最大值
int s = 1;//和上面同理
for(int i = 0; i < n; i++){
//控制空格输出
for(int j = 0; j < Math.abs(space-s); j++){
System.out.print(" ");
}
s++;
//控制*号输出
for(int k = 0; k < n - Math.abs(n - m); k++){
System.out.print("*");
}
m += 2;
System.out.println();
}
}
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
int i,j,k; for(i=1;i<=5;i++){ for(j=1;j<=5-i;j++) System.out.print(" "); for(k=1;k<=2*i-1;k++) System.out.print("*"); System.out.println("");} for(i=1;i<=4;i++){ for(j=1;j<=i;j++) System.out.print(" "); for(k=1;k<=9-2*i;k++) System.out.print("*"); System.out.println("");}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询