天天看点

蓝桥杯-基础练习 字母图形

问题描述

利用字母可以组成一些美丽的图形,下面给出了一个例子:

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=;i<n;i++)//第一列为A,B,C。。。。
        array[i][]=+i;//A的ASCII码为65

    for(i=;i<m;i++)//第一行为A,B,C。。。。
        array[][i]=+i;

    for(i=;i<n;i++)//从第二行开始每行都是上一行的前一个
        for(j=;j<m;j++)//从第二行开始,每一行从第二位数开始的值都是上一行的右移一位后直接搬下来的
            array[i][j]=array[i-][j-];

    for(i=;i<n;i++){//输出

        for(j=;j<m;j++){

            cout<<(char)array[i][j];//强制转换成字符
        }
        cout<<endl;
    }   
    return ;
}
           

方法二:

字母的序号与两个坐标的差的绝对值有关。
#include<iostream>
#include<cmath>                   //一定别漏了
using namespace std;
int main()
{
    int n,m;
    cin>>n>>m;
    int array[n][m];
    for(int i=;i<n;i++)
        for(int j=;j<m;j++)
            array[i][j]=(+abs(i-j));//很重要

    for(int i=;i<n;i++){

        for(int j=;j<m;j++){

            cout<<(char)array[i][j];
        }
        cout<<endl;
    }           
    return ;
} 
           

其实也没有很难,关键是方法,找到规律就很简单,加油吧,小伙子!