02 required to print the stars

1 Print triangle

triangle


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));
			}
		}
	}
}

2 Print "necklace"

necklace


/**
 * 面向对象的思维,把星星看做一个整体,思考就简单得多
 * 切记一个方法只做一件事情
 * @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();
	}
}

Guess you like

Origin www.cnblogs.com/alichengxuyuan/p/12578003.html