蓝桥杯试题 基础练习 BASIC-3 字母图形 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。

方法一

思路:a[i][j] = (char) ('A' + Math.abs(i - j));
第i行第j列的字母为:A之后的第(i和j差的绝对值)个字母

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();
        sc.close();
        char[][] a = new char[n][m];
        for (int i = 0; i < n; i++) {
            for (int j = 0; j < m; j++) {
                a[i][j] = (char) ('A' + Math.abs(i - j));
                // 放数组里代码方便看,不然 System.out.print((char) ('A' + Math.abs(i - j)));很难看,
                // 当然用个临时变量也行,tmp= (char) ('A' + Math.abs(i - j))
                System.out.print(a[i][j]);
            }
            System.out.println();
        }
    }
}

方法二

思路:先创建Z-A-Z的字符串
"ZYXWVUTSRQPONMLKJIHGFEDCBABCDEFGHIJKLMNOPQRSTUVWXYZ";
然后再从该字符串中截取结果需要的每行字符串

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();
        String letterZ_A_Z="ZYXWVUTSRQPONMLKJIHGFEDCBABCDEFGHIJKLMNOPQRSTUVWXYZ";
        sc.close();
        for (int i = 0; i < n; i++) {
            System.out.println(letterZ_A_Z.substring(25-i,25+m-i));
        }
    }
}

方法三

思路:
array[i + 1] = (char) ('A' + i + 1) + array[i].substring(0, m - 1);
第一列永远为A-Z,下一行:第一列固定字母+上一行前四位
例如"ABCDE"的下一行:'B'+"ABCD",该行为第二行,所以第一列固定字母为'B'+上一行前四位"ABCD"

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();
        sc.close();
        String[] array = new String[n];
        array[0] = "";
        for (int i = 0; i < m; i++) {
            array[0] += (char) ('A' + i);
        }
        for (int i = 0; i < n - 1; i++) {
            array[i + 1] = (char) ('A' + i + 1) + array[i].substring(0, m - 1);
        }
        for (String i : array) {
            System.out.println(i);
        }
    }
}

方法四

思路:
array[i + 1] = (char) (array[i].toCharArray()[0]+1) + array[i].substring(0, m - 1);
和方法三除了此条代码前半部分不一样,其他都一样
下一行字符串:上一行第一位的字母的后一位+上一行前四位
例如"ABCDE"的下一行:'B'+"ABCD"'A'的后一位'B'+上一行前四位"ABCD"

import java.util.Scanner;

public class LetterGraph4 {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int m = sc.nextInt();
        sc.close();
        String[] array = new String[n];
        array[0] = "";
        for (int i = 0; i < m; i++) {
            array[0] += (char) ('A' + i);
        }
        for (int i = 0; i < n - 1; i++) {
            array[i + 1] = (char) (array[i].toCharArray()[0]+1) + array[i].substring(0, m - 1);
        }
        for (String i : array) {
            System.out.println(i);
        }
    }
}
发布了102 篇原创文章 · 获赞 101 · 访问量 2万+

猜你喜欢

转载自blog.csdn.net/weixin_43124279/article/details/104899763