第五届蓝桥杯——基础练习:字母图形

本文详细阐述了如何通过字母组合生成特定的图形模式,并提供了一个算法实现,该算法可根据输入的行数和列数自动生成相应的图形。文章深入探讨了算法背后的逻辑与实现细节,包括如何确定图形的构建规律以及如何优化输出过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题描述

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

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 Main {  
      
        public static void main(String[] args) {  
            Scanner input=new Scanner(System.in);  
            int n=input.nextInt();  
            int m=input.nextInt();  
            char[][] charArr=new char[n][m];  
            input.close();  
            char[] c=new char[m>n?m:n];  
            int tc=65;  
            for (int i = 0; i < c.length; i++) {  
                c[i]=(char)tc;  
                tc++;  
            }  
            for (int i = 0; i < n; i++) {  
                for (int j = 0; j < n-i&&i<m; j++) {  
                    charArr[j+i][i]=c[j];  
                }  
                for (int j = 0; j < m-i; j++) {  
                    charArr[i][j+i]=c[j];  
                }  
            }  
            for (int i = 0; i < n; i++) {  
                for (int j = 0; j < m; j++) {  
                    System.out.print(charArr[i][j]);  
                }  
                System.out.println();  
            }  
        }  
      
    } 
 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值