(蓝桥杯第九届省赛)打印等腰三角形


本题目要求你在控制台输出一个由数字组成的等腰三角形。
具体的步骤是:
1. 先用1,2,3,...的自然数拼一个足够长的串
2. 用这个串填充三角形的三条边。从上方顶点开始,逆时针填充。
比如,当三角形高度是8时:


       1
      2 1
     3   8
    4     1
   5       7
  6         1
 7           6
891011121314151


输入,一个正整数n(3<n<300),表示三角形的高度
输出,用数字填充的等腰三角形。


为了便于测评,我们要求空格一律用"."代替。


例如:
输入:
5


程序应该输出:
....1
...2.1
..3...2
.4.....1
567891011


再例如:
输入:
10


程序应该输出:
.........1
........2.2
.......3...2
......4.....2
.....5.......1
....6.........2
...7...........0
..8.............2
.9...............9
1011121314151617181


再例如:
输入:
15


程序应该输出:


..............1
.............2.3
............3...2
...........4.....3
..........5.......1
.........6.........3
........7...........0
.......8.............3
......9...............9
.....1.................2
....0...................8
...1.....................2
..1.......................7
.1.........................2
21314151617181920212223242526




资源约定:
峰值内存消耗(含虚拟机) < 256M
CPU消耗  < 1000ms

import java.util.Arrays;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Queue;
import java.util.Scanner;
import java.util.Set;

public class Main{
	public static void main(String[] args){
		Scanner input = new Scanner(System.in);
		
		StringBuilder data = new StringBuilder();
		int row = input.nextInt();
		
		//全部的数字长度
		//左边长度是 行高  右边的高度也是行高   左右共用一个顶点
		//地层长度是高度*2减1  再减去 左右 的数字  === row*2-3
		// row +row-1 + row*2-3 =总长度
		//row+row+row+row - 4 == row*4 - 4
		int total = row*4-4;
		
		for(int i=0,index=1;i<total;){
			data.append(index);
			i+= String.valueOf(index).length();
			index++;
		}
		data.setLength(total);
		
		int index = 0;
		//打印第一行
		for(int i=1;i<row;i++){
			System.out.print(".");
		}
		System.out.print(data.charAt(index++));
		System.out.println();
		//打印  2 - row-1 行
		for(int i=2;i<row;i++){
			//打印点
			for(int j=0;j<row-i;j++){
				System.out.print(".");
			}
			System.out.print(data.charAt(index++));
			
			//打印中间的点
			for(int j=0;j<1+(i-2)*2;j++){
				System.out.print(".");
			}
			System.out.print(data.charAt(total-index+1));
			System.out.println();
		}
		
		//打印最后一排
		for(int i=0;i<row*2-1;i++){
			System.out.print(data.charAt(index++));
		}
		
	}
	
	
	
	
}
	

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SUNbrightness

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值