问题描述
利用字母可以组成一些美丽的图形,下面给出了一个例子:
ABCDEFG
BABCDEF
CBABCDE
DCBABCD
EDCBABC
这是一个5行7列的图形,请找出这个图形的规律,并输出一个n行m列的图形。
输入格式
输入一行,包含两个整数n和m,分别表示你要输出的图形的行数的列数。
输出格式
输出n行,每个m个字符,为你的图形。
样例输入
5 7
样例输出
ABCDEFG
BABCDEF
CBABCDE
DCBABCD
EDCBABC
数据规模与约定 1 <= n, m <= 26。
方法一代码
#include<iostream>
using namespace std;
int main()
{
int n,m;
cin>>n>>m;
int array[n][m]; //n行m列
int i,j;
for(i=0;i<n;i++)//第一列为A,B,C。。。。
array[i][0]=65+i;//A的ASCII码为65
for(i=0;i<m;i++)//第一行为A,B,C。。。。
array[0][i]=65+i;
for(i=1;i<n;i++)//从第二行开始每行都是上一行的前一个
for(j=1;j<m;j++)//从第二行开始,每一行从第二位数开始的值都是上一行的右移一位后直接搬下来的
array[i][j]=array[i-1][j-1];
for(i=0;i<n;i++){//输出
for(j=0;j<m;j++){
cout<<(char)array[i][j];//强制转换成字符
}
cout<<endl;
}
return 0;
}
方法二:
字母的序号与两个坐标的差的绝对值有关。
#include<iostream>
#include<cmath> //一定别漏了
using namespace std;
int main()
{
int n,m;
cin>>n>>m;
int array[n][m];
for(int i=0;i<n;i++)
for(int j=0;j<m;j++)
array[i][j]=(65+abs(i-j));//很重要
for(int i=0;i<n;i++){
for(int j=0;j<m;j++){
cout<<(char)array[i][j];
}
cout<<endl;
}
return 0;
}
其实也没有很难,关键是方法,找到规律就很简单,加油吧,小伙子!