资源限制
时间限制: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。
代码1——二维数组:
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int n = in.nextInt();
int m = in.nextInt();
in.close();
char[][] a= new char[n][m];
if(n>=1 && m<=26)
for(int i =0;i<n;i++) {
for(int j =0;j<m;j++) {
if(j==i) {
a[i][j] = (char)('A'+0);
}
else {
a[i][j] =(char)('A'+Math.abs(i-j));
}
System.out.print(a[i][j]);
}
System.out.println();
}
}
}
代码二——一维数组:
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt() ; //行
int m = sc.nextInt() ; //列
char [] a = new char [26] ;
char c = 'A';
for(int i = 0; i < 26; i++ ) {
a[i] =(char)( c + i ) ;
}
for( int i = 0 ; i < n ; i++ ) {
for( int j = i ; j >= 0 ; j-- )
System.out.print(a[j]);
for( int k = 1 ; k < m - i ; k++ )
System.out.print(a[k]);
System.out.println();
}
}
}