import java.util.Scanner;
/**
* 面向对象的思维,把星星看做一个整体,思考就简单得多
* 切记一个方法只做一件事情
* @author zhangli
*
*/
public class PrintStars {
/**
* 生成动态的星星与空格组合
* @param n
* @return
*/
public static String[] initStarArray(int n){
String[] arr=new String[n];
for(int i=0;i<n;i++){
arr[i]=printString("*",2*i+1)+printString(" ",2*n-1-2*i);
}
return arr;
}
/**
* 将str拼接num次得到结果
* @param str
* @param num
* @return
*/
public static String printString(String str ,int num){
StringBuffer sb=new StringBuffer();
for(int i=0;i<num;i++){
sb.append(str);
}
return sb.toString();
}
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
System.out.println("请输入小三角的层数:");
int n=sc.nextInt();
System.out.println("请输入大三角的层数:");
int m=sc.nextInt();
//初始化要打印的星星以及空格,动态生成
String[] stars=initStarArray(n);
//计算出要打印的空格个数
int num=n*m;
for(int i=0;i<m;i++){
for(int j=0;j<n;j++){
//打印空格,每次减小
System.out.print(printString(" ",num--));
//打印对应的星星,j刚好是所需星星数组的下标
System.out.println(printString(stars[j],i+1));
}
}
}
}
/**
* 面向对象的思维,把星星看做一个整体,思考就简单得多
* 切记一个方法只做一件事情
* @author zhangli
*
*/
public class PrintDiamond
{
public static void main(String[] args)
{
int m = 10;
//每行输出之前,空格是要先打印的,打印次数先增大,后减小
int spaceNum = m;
for (int i = 0; i < m; i++)
{
String strSpace = PrintDiamond.printChars(" ", spaceNum--);
String star = PrintDiamond.printChars("*", 2 * (i + 1) - 1);
System.out.println(strSpace + star);
}
//for循环中多减了一次,这里就要加上去
++spaceNum;
for (int i = m - 2; i >= 0; i--)
{
String strSpace = PrintDiamond.printChars(" ", ++spaceNum);
String star = PrintDiamond.printChars("*", 2 * (i + 1) - 1);
System.out.println(strSpace + star);
}
}
/**
* 将sourceStr拼接length次,得到结果
* @param sourceStr
* @param length
* @return
*/
public static String printChars(String sourceStr, int length)
{
StringBuffer sb = new StringBuffer(64);
for (int i = 0; i < length; i++)
{
sb.append(sourceStr);
}
return sb.toString();
}
}
原文:https://www.cnblogs.com/alichengxuyuan/p/12578003.html