Java蓝桥模拟战——字母图形

资源限制

时间限制: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();
			}
		}
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章