问题描述
利用字母可以组成一些美丽的图形,下面给出了一个例子:
ABCDEFG
BABCDEF
CBABCDE
DCBABCD
EDCBABC
这是一个5行7列的图形,请找出这个图形的规律,并输出一个n行m列的图形。
输入格式
输入一行,包含两个整数n和m,分别表示你要输出的图形的行数的列数。
输出格式
输出n行,每个m个字符,为你的图形。
样例输入
5 7
样例输出
ABCDEFG
BABCDEF
CBABCDE
DCBABCD
EDCBABC
数据规模与约定
1 <= n, m <= 26。
详细代码
import java.util.Scanner;
public class 试题_基础练习_字母图形 {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
//开始接受数据
Scanner scanner = new Scanner(System.in);
//接收一个H常数为行,L常数为列
int H = scanner.nextInt();
int L = scanner.nextInt();
//首先需要设置一个26字母的数组作为对照组 char[]
char[] DZ = { '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' };
//定义一个数组char[]用于储存每一行的数据
//设定一个循环 i<H
for (int i = 0; i < H; i++)
{
char[] SC = new char[L];
int f = 0;
//循环里再设置一个循环 j=i,j<L-i
for (int j = i; j < L; j++)
{
if (f<L-i)
{
SC[j] = DZ[f];
f++;
}
}
//并且在循环直接循环输入所得的char[]数组
int x = 0;
for (int j = i; j > 0; j--)
{
if (x<SC.length) {
SC[x] = DZ[j];
x++;
}
}
for (int j = 0; j < L; j++)
{
System.out.print(SC[j]);
}
System.out.println();
}
}
}