蓝桥杯 2018年第九届真题 等腰三角形

题目 2282: [蓝桥杯][2018年第九届真题]等腰三角形

                        时间限制: 1Sec 内存限制: 128MB 提交: 41 解决: 33
                
            

            

            
                题目描述
                本题目要求你在控制台输出一个由数字组成的等腰三角形。

具体的步骤是:

  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

在这里插入图片描述

#include<iostream>
#include<algorithm>
using namespace std;
int dfs(int &a)
{
	int x;
	if(a<10)
	{
	  x=a;
	  a/=10;
	  return x;
	}
	if(a<100&&a>=10)
	{
		x=a/10;
		a=a%10;
		return x;
	}
	
}


int main()
{
   int n;
   cin>>n;
   
   int w=3*n;
   int cns=1;
   int str[1005];
   for(int i=1;i<=w;i++)
   {
   	 if(i%10==0)
   	  {
   		str[cns++]=(i/10);
   		str[cns++]=0;
   		continue;
	   }
   	  int z=i;
   	  while(z>0)
   	  {
   	  	str[cns++]=dfs(z); 
		  }
   }
   int ans=4*(n-1);
   int tns=1;
   int i,j,k;
   for(int i=1;i<=n;i++)
   {
   	 for(int k=n-i;k>=1;k--)
   	 {
   	 	cout<<'.';
		}
	 for(int j=i*2-1;j>=1;j--)
	 {
	 	  if(j==i*2-1)
	 	  {
	 	  	cout<<str[tns++];
		   }
		   else if(j==1)
		   {
		   	cout<<str[ans--];
		   }
		   else if(i==n)
		   {
		   	cout<<str[tns++];
		   }
		   else cout<<'.';
	 }
	 	cout<<endl;
   }
	return 0;
}

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值