• Java实现 蓝桥杯VIP 算法训练 输出米字形


    例如:n=3时,包含A,B,C;n=4时,包含A,B,C,D。
      矩阵的正中间为n个字母中字典序最大的那个,从这个字母开始,沿着西北、正北、东北、正西、正东、西南、正南、东南八个方向各有一条由大写字母组成的直线。并且直线上的字母按字典序依次减小,直到大写字母A。
      矩阵的其它位置用英文句号.填充。

    样例输入一
      3

    样例输出一
      A.A.A
      .BBB.
      ABCBA
      .BBB.
      A.A.A

    样例输入二
      4

    样例输出二
      A..A..A
      .B.B.B.
      ..CCC..
      ABCDCBA
      ..CCC..
      .B.B.B.
      A..A..A

    import java.util.Scanner;
    
    
    public class 输出米字形 {
    	   public static void main(String[] args) {
    	        Scanner scanner = new Scanner(System.in);
    	        int n = scanner.nextInt();
    	        char[][] a = new char[2 * n - 1][2 * n - 1];
    	        int tmp1 = 0;
    	        int tmp2 = n-1;
    	        for (int i = 0; i < 2 * n - 1; i++) {//初始化为0
    	            for (int j = 0; j < 2 * n - 1; j++) {
    	                a[i][j] = '0';
    	            }
    	        }
    	        char x = 'A';
    	        for (int i = 0; i <= n - 2; i++) {//前n-2行
    	            for (int j = tmp1; j < 2 * n - 1; j += tmp2) {
    	                a[i][j] = x;
    	            }
    	            if (i == n-2){
    	                for (int j = i+3;j<2*n-1;j++){
    	                    a[i][j] = '.';
    	                }
    	            }
    	            x += 1;
    	            tmp1++;
    	            tmp2--;
    	        }
    
    	        int count = 0;
    	        for (int i = 2*n-2; i >=n; i--) {//上半部分复制给下半部分
    	            for (int j = 0; j < 2 * n - 1; j++) {
    	                a[i][j] = a[count][j];
    	            }
    	            count++;
    	        }
    	        x = 'A';
    	        for (int i = 0;i<2*n-1;i++){//中间行赋值ABCD...
    	            a[n-1][i] = x;
    	            x+=1;
    	        }
    	        x = 'A';
    	        for (int i = 2*n-2;i>=3;i--){//修改到应有的字母,例如CBA
    	            a[n-1][i] = x;
    	            x+=1;
    	        }
    	        for (int i = 0; i < 2 * n - 1; i++) {//输出
    	            for (int j = 0; j < 2 * n - 1; j++) {
    	                if (a[i][j] == '0') {
    	                    a[i][j] = '.';
    	                }
    	                System.out.print(a[i][j]);
    	            }
    	            System.out.println();
    	        }
    	    }
    
    }
    
    
  • 相关阅读:
    WUSTOJ 1247: 递增或递减排序(Java)
    WUSTOJ 1246: 字符串排序(Java)
    Oracle查询部门工资最高员工的两种方法 1、MAX()函数 2、RANK()函数
    Oracle数据库——用户(USER)
    Firefox在新标签页打开“书签”和“搜索栏”(无需插件)
    Oracle数据库——ROWNUM
    Oracle数据库 SET ECHO [ON|OFF]
    WUST Oracle数据库 实验一实验二
    优课在线 嵌入式系统(胡威)2018春季测验 参考解析
    Oracle数据库——查询所有用户
  • 原文地址:https://www.cnblogs.com/a1439775520/p/13078630.html
Copyright © 2020-2023  润新知