问题描述
利用字母可以组成一些美丽的图形,下面给出了一个例子:
ABCDEFG
BABCDEF
CBABCDE
DCBABCD
EDCBABC
这是一个5行7列的图形,请找出这个图形的规律,并输出一个n行m列的图形。
输入格式:
输入一行,包含两个整数n和m,分别表示你要输出的图形的行数的列数。
输出格式:
输出n行,每个m个字符,为你的图形。
样例输入:
5 7
样例输出:
ABCDEFG
BABCDEF
CBABCDE
DCBABCD
EDCBABC
BABCDEF
CBABCDE
DCBABCD
EDCBABC
数据规模与约定:
1 <= n, m <= 26。
首先观察规律,n行m列,也就是n行,每行m个字符。在看输出,一共输出n行,第一行为全部正着输出,第二行开始倒着输出的个数+1,正着输出的个数减1,但是每行总个数依然为m个。
首先做一个大循环,控制行数。在大循环中,在写对倒着输出和正着输出写两个循环。
在细节,对于正着输出,第一行等于字符个数(m),每行输出之后,正着输出的总数减1。知道m=0,之后,全部为导着输出。所以开始定义m2=m;每次循环之后,总数减1(m2--)。
对于倒着输出,第一行全部为正着输出,第二行开始有倒着输出,每行输出之后,倒着输出的总数加1。
最后对于26个英文字符,我用的是char数组。可能相对麻烦了。。
#include <iostream>
using namespace std;
int main() {
int n,m; //n行数,m字符个数
int m1,m2; //倒数个数和开始个数
char K[26] = {
'A','B','C','D','E','F','G',
'H','I','J','K','L','M','N',
'O','P','Q','R','S','T','U',
'V','W','X','Y','Z'
};
cin>>n;
cin>>m;
m1 = 0;
m2 = m;
while(n > 0)
{
int k;
if(m1 > m)
k = m1-m;
else
k = 0;
for(int i=m1;i>k;i--) //倒着输出
cout<<K[i];
for(int i=0;i<m2;i++)
cout<<K[i];
cout<<'\n';
m1++;
m2--;
n--;
}
return 0;
}
最后,今天开始继续慢慢写博客。之前太忙了,数学建模,机器人项目等等。