问题描述
利⽤字⺟可以组成⼀些美丽的图形,下⾯给出了⼀个例⼦:
ABCDEFG
BABCDEF
CBABCDE
DCBABCD
EDCBABC
这是⼀个5⾏7列的图形,请找出这个图形的规律,并输出⼀个n⾏m列的图形。
输⼊格式
输⼊⼀⾏,包含两个整数n和m,分别表示你要输出的图形的⾏数的列数。
输出格式
输出n⾏,每个m个字符,为你的图形。
样例输⼊
5 7
样例输出
ABCDEFG
BABCDEF
CBABCDE
DCBABCD
EDCBABC
数据规模与约定
1 <= n, m <= 26。
思路
每一行的输出个数都是固定的,其中第一个字母不断递增,A的位置不断后移,其中第 i 行的A处于索引为 i 的位置,因此每一行的第一个字母为 char(‘A’+i)
,之后递减i次,然后递增直到补满m个字母
#include <iostream>
using namespace std;
int main()
{
int n,m;
cin >> n >> m;
for(int i = 0; i < n; i++)
{
for(int j = i; j > 0; j--)
{
cout << char('A' + j);
}
for(int j = 0; j < m - i; j++)
{
cout << char('A' + j);
}
cout << endl;
}
}