蓝桥杯 BASIC-3 字母图形
【摘要】 试题 基础练习 字母图形提交此题 评测记录 资源限制时间限制:1.0s 内存限制:256.0MB问题描述利用字母可以组成一些美丽的图形,下面给出了一个例子:ABCDEFGBABCDEFCBABCDEDCBABCDEDCBABC这是一个5行7列的图形,请找出这个图形的规律,并输出一个n行m列的图形。输入格式输入一行,包含两个整数n和m,分别表示你要输出的图形的行数的列数。输出格式输出...
试题 基础练习 字母图形
资源限制
时间限制:1.0s 内存限制:256.0MB
问题描述
利用字母可以组成一些美丽的图形,下面给出了一个例子:
ABCDEFG
BABCDEF
CBABCDE
DCBABCD
EDCBABC
这是一个5行7列的图形,请找出这个图形的规律,并输出一个n行m列的图形。
输入格式
输入一行,包含两个整数n和m,分别表示你要输出的图形的行数的列数。
输出格式
输出n行,每个m个字符,为你的图形。
样例输入
5 7
样例输出
ABCDEFG
BABCDEF
CBABCDE
DCBABCD
EDCBABC
BABCDEF
CBABCDE
DCBABCD
EDCBABC
数据规模与约定
1 <= n, m <= 26。
解题思路思路如下---
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
// 分析
/**
* 因为字母都有自己对应的ASCII码,所以可以将题目给出的字母图形变成数字来看。 A=65 B=66 C=67 A=0+65 B=1+65 C=2+65 即
* 可以变形 变形后,就形成了一个有规律的矩阵: 0123456 1012345 2101234 3210123 4321012
* 结合规律可以的到,每一个坐标所对应的数字则为它本身的(x-y)的绝对值 如: 第一行第三列坐标为(1,3)
* 1-3的绝对值为2,所以第一行第三列对应的数字为2
*/
// 接收数据
Scanner sc = new Scanner(System.in);
// 行数
int x = sc.nextInt();
// 列数
int y = sc.nextInt();
// 外层for循环为X
for (int i = 0; i < x; i++) {
// 内层for循环为Y
for (int j = 0; j < y; j++) {
// 该坐标对应的字母,为横坐标减去纵坐标的绝对的+65(A)
char a = (char) (Math.abs(i - j) + 65);
// char a = (char) (Math.abs(i - j) + 'A');
System.out.print(a);
}
System.out.println();
}
}
}
.
最终效果如下--

希望对大家有所帮助!
谢谢大家!
【声明】本内容来自华为云开发者社区博主,不代表华为云及华为云开发者社区的观点和立场。转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
作者其他文章
评论(0)