思路:将菱形分为3部分,正三角形,最长段,倒三角形。
一些注意点:1.中间段的 * 等同于菱形行数;
2.要对输入的行数进行判断是否为奇数。
附上代码:
import java.util.Scanner;
public class bb
{
public static void main(String[] args)
{
Scanner sc = new Scanner(System.in);
int a;
//判断是否有效
do{
System.out.println("请输入菱形的行数:");
a = sc.nextInt();
}while(a%2 == 0 || a <= 0);
f(a/2); //定义一个函数 f,意为输入所求菱形行数(最好是奇数)
}
public static void f(int hang)
{
//正三角形
for(int i=0;i<hang;i++)
{
int k=hang-i; //定义k与b 输出空格,具体数量由行决定
int b=0;
while(b<k)
{
System.out.print(" ");
b++;
}
int v=2*i+1; //定义v 输出*,注:终端输出是连续的
int c=0;
while(c<v)
{
System.out.print("*");
c++;
} System.out.println(" "); //换行
}
//中间最长的一行
int mid = 2*hang+1;
int x=0;
while(x<mid)
{
System.out.print("*"); //最长的一行的*数量和行数一样
x++;
} System.out.println(" "); //换行
//倒三角形
for(int i=0;i<hang;i++)
{
int k=i+1; //就是前面的倒输出
int b=0;
while(b<k)
{
System.out.print(" ");
b++;
}
int v=2*(hang-i)-1;
int c=0;
while(c<v)
{
System.out.print("*");
c++;
} System.out.println();
}
}
}
尝试运行:
请输入菱形的行数:
5
*
***
*****
***
*
进程已结束,退出代码0