2018蓝桥C语言混搭 8.等腰三角形 string操作。。和char[]不一样

标题:等腰三角形

本题目要求你在控制台输出一个由数字组成的等腰三角形。
具体的步骤是:

  1. 先用1,2,3,…的自然数拼一个足够长的串

  2. 用这个串填充三角形的三条边。从上方顶点开始,逆时针填充。
    比如,当三角形高度是8时:

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

显示不正确时,参看:p1.png

输入,一个正整数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

请严格按要求输出,不要画蛇添足地打印类似:“请您输入…” 的多余内容。

注意:
main函数需要返回0;
只使用ANSI C/ANSI C++ 标准;
不要调用依赖于编译环境或操作系统的特殊函数。
所有依赖的函数必须明确地在源文件中 #include
不能通过工程设置而省略常用头文件。

提交程序时,注意选择所期望的语言类型和编译器类型。

——————————————————————————————————————————————

  • string s,st;
    s[i]=st[j] ×
#include<iostream>
#include<cstdio>
using namespace std;
int n;
char a[400][800];
string s,st;
int main()
{
	scanf("%d",&n);
	int l=n+2*(n-1)+n-2;
	int t,tt=1,i=0,j;
	while(i<l){
		t = tt++;
		j=0;
		while(t){
			st[++j]=t%10+'0';
			t/=10;
		}
		while(j)//s[i++]=st[j--] × 
		{
			s += st[j--];
			i++;
		}	
	}
	fill(a[0],a[0]+400*800,'.');
	j=0;
	for(i=0;i<n;i++)
		a[i][n-1-i]=s[j++];
	for(i=1;i<n+n-1;i++)
		a[n-1][i]=s[j++];
	for(i=n-2;i>0;i--)
		a[i][n-1+i]=s[j++];
		
	for(i = 0;i < n; i++){
		for(j = 0;j < n + i;j++){
			printf("%c",a[i][j]);
		}
		printf("\n");
	}
	return 0;
}
    原文作者:杨辉三角问题
    原文地址: https://blog.csdn.net/weixin_40367307/article/details/88758049
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞