lqb 基础练习 字母图形 (循环)

基础练习 字母图形  

时间限制:1.0s   内存限制:256.0MB
   
问题描述

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

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的位置,循环实现
 
核心代码:
 
 1 for(int i = 1; i <= n; ++ i)
 2 {
 3     A[i] = 'A';
 4     for (int j = i - 1; j >= 1; ++ j)
 5         A[i] = char(A[i+1] + 1);
 6     for (int j = i + 1; j <= m; ++ j)
 7         A[i] = char(A[i-1] + 1);
 8     for (int j = 1; j <= m; ++ j)
 9         printf("%c", A[j]);
10     printf("\n");
11 }

 

C/C++代码实现(AC):
  
 1 #include <iostream>
 2 #include <algorithm>
 3 #include <cstring>
 4 #include <cstdio>
 5 #include <cmath>
 6 #include <stack>
 7 #include <map>
 8 #include <queue>
 9 
10 using namespace std;
11 char A[30][30];
12 
13 int main()
14 {
15     int n, m;
16     scanf("%d%d", &n, &m);
17     for(int i = 1; i <= n; ++ i)
18     {
19         A[i][i] = 'A';
20         for(int j = i - 1; j >= 1; -- j)
21             A[i][j] = char(A[i][j + 1] + 1);
22         for(int j = i + 1; j <= m; ++ j)
23             A[i][j] = char(A[i][j - 1] + 1);
24         for(int j = 1; j <= m; ++ j)
25             printf("%c", A[i][j]);
26         printf("\n");
27     }
28     return 0;
29 }

 

posted @ 2018-05-14 08:46  GetcharZp  阅读(457)  评论(0编辑  收藏  举报