原题链接:蓝桥杯2013年第四届真题-打印十字图
import java.util.Scanner;
public class 打印十字图 {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
int col = 1;
for (int i = 0; i <= n; i++) {
col += 4;
}
int[][] arr = new int[col][col];
//首先将最外围的一圈写出来
for (int i = 2; i < col-2; i++) {
arr[0][i] = arr[col-1][i]= arr[i][col-1] = arr[i][0] = 1;
//四个内折角表示出来
if (i % 2 == 0) {
arr[i][i] = arr[col-1-i][i] = 1;
if (i <= col/2+1) {
arr[i-1][i] = arr[i][i-1] =
arr[col-1-i+1][i] = arr[col-1-i][i-1] = 1;
arr[col-i-1+1][col-1-i] = arr[col-1-i][col-i-1+1] =
arr[i][col-1-i+1] = arr[i-1][col-i-1] = 1;
}
}
}
//将每一圈的上下左右边表示出来
for (int i = 2; i <= col-1-2; i+=2) {
for (int j = i+2; j <= col-1-i-2; j++) {
arr[i][j] = arr[col-1-i][j] = arr[j][i] = arr[j][col-1-i] = 1;
}
}
//判断是否还存在落下的点没有处理
if (arr[col/2-1-2][col/2] == 0) {
arr[col/2-1-1][col/2] = 1;
}
if (arr[col/2+1+2][col/2] == 0) {
arr[col/2+1+1][col/2] = 1;
}
if (arr[col/2][col/2-1-2] == 0) {
arr[col/2][col/2-1-1] = 1;
}
if (arr[col/2][col/2+1+2] == 0) {
arr[col/2][col/2+1+1] = 1;
}
//最后通过数组中的0和1来表示最终结果
for (int i = 0; i < col; i++) {
for (int j = 0; j < col; j++) {
if (arr[i][j] == 1 ) {
System.out.print("$");
}else if (arr[i][j] == 0 ) {
System.out.print(".");
}
}
System.out.println();
}
}
}
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复