【java_蓝桥杯算法训练】算法训练 输出米字形

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

 

算法训练 输出米字形

资源限制

时间限制:1.0s   内存限制:512.0MB

  根据输入的正整数n (1  米字形由一个(2n-1)*(2n-1)的矩阵组成,矩阵包含从大写A开始的n个字母

  例如: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


分析:

本题目要求是输出米字形,要求是 正整数n (1  米字形由一个(2n-1)*(2n-1)的矩阵组成。把他当作数组来进行模拟,也就是一个二位数组行和列都是2*n-1,数组中心数为n的值 例如:n=3时,包含A,B,C;n=4时,包含A,B,C,D。根据样例输出可以数组最中心的值为n,我们可以使用char(64+n)来表示,分为西北、正北、东北、正西、正东、西南、正南、东南八个方向来做,这类题目不难就是比较麻烦,掌握其规律就比较容易了。

代码详细解读:

import java.util.Iterator;
import java.util.Scanner;
public class Main {
  public static void main(String[] args) {
    // TODO Auto-generated method stub
    Scanner sc=new Scanner(System.in);
    //用n来接受n传入的值
    int n=sc.nextInt();
    //定义一个char类型的二位数组,用来存放[2*n-1][2*n-1]个大小的数据;
    char arr[][]=new char[2*n-1][2*n-1];
    //对数组进行初始化,设置为'.'
    for (int i = 0; i < 2*n-1; i++) {
      for (int j = 0; j < 2*n-1; j++) {
        arr[i][j]='.';
      }
    }
    //我们先设置好数组的中心arr[n-1][n-1]为中心
    char c=(char) (64+n);
    //给数组中心赋值为(64+n)也就是大写字母
    arr[n-1][n-1]=c;
    //给西北方向赋值i和j没次-1
//    22——>11——>00这样的格式,然后按照arr[i+1][i+1]-1,对下一个就等于的上一个-1
    //西北
    for (int i = n-2; i>-1; i--) {
      arr[i][i]=(char) (arr[i+1][i+1]-1);
    }
//    和西北大致相同
//    东南是i-1 j+1的格式进行可以
    //东南
    for (int i = n; i<2*n-1; i++) {
      arr[i][i]=(char) (arr[i-1][i-1]-1);
    }
//  和东南类似
    //东北
    int u=n;
    for (int i = n-2; i>=0; i--) { 
      arr[i][u]=(char) (arr[i+1][u-1]-1);
      u++;
    }
//    正南和正北只需要对y的值进行变化即可
    //西南
    int k=n-2;
     for (int i = n;i<2*n-1; i++) {
     arr[i][k]=(char) (arr[i-1][k+1]-1);
     k--;
  }
     //正北
     for (int i = n-2; i >-1; i--) {
    arr[i][n-1]=(char) (arr[i+1][n-1]-1);
  }
//     正西和正东只需要对x的值进行变化即可
     //正西
     for (int i = n; i<2*n-1; i++) {
    arr[i][n-1]=(char) (arr[i-1][n-1]-1);
  }
     //正东
     for (int i = n; i <2*n-1; i++) {
    arr[n-1][i]=(char) (arr[n-1][i-1]-1);
    }
     //正西
     for (int i = n-2; i>=0; i--) {
    arr[n-1][i]=(char) (arr[n-1][i+1]-1);
  }
     for (int i = 0; i < 2*n-1; i++) {
        for (int j = 0; j <2*n-1 ; j++) {
          if(arr[i][j]!=' ')
          System.out.print(arr[i][j]);
        }
        System.out.println();
      }
  }
  }

image.gif

目录
相关文章
|
24天前
|
存储 人工智能 算法
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
这篇文章详细介绍了Dijkstra和Floyd算法,这两种算法分别用于解决单源和多源最短路径问题,并且提供了Java语言的实现代码。
61 3
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
|
27天前
|
Python
蓝桥杯练习题(一):Python组之入门训练题
这篇文章是关于蓝桥杯Python组的入门训练题,包括Fibonacci数列、圆的面积、序列求和和A+B问题的具体代码实现和样例输出。
93 0
|
1月前
|
算法 测试技术 C++
【动态规划算法】蓝桥杯填充问题(C/C++)
【动态规划算法】蓝桥杯填充问题(C/C++)
|
27天前
|
存储 机器学习/深度学习 算法
蓝桥杯练习题(三):Python组之算法训练提高综合五十题
蓝桥杯Python编程练习题的集合,涵盖了从基础到提高的多个算法题目及其解答。
50 3
蓝桥杯练习题(三):Python组之算法训练提高综合五十题
|
7天前
|
分布式计算 Java 开发工具
阿里云MaxCompute-XGBoost on Spark 极限梯度提升算法的分布式训练与模型持久化oss的实现与代码浅析
本文介绍了XGBoost在MaxCompute+OSS架构下模型持久化遇到的问题及其解决方案。首先简要介绍了XGBoost的特点和应用场景,随后详细描述了客户在将XGBoost on Spark任务从HDFS迁移到OSS时遇到的异常情况。通过分析异常堆栈和源代码,发现使用的`nativeBooster.saveModel`方法不支持OSS路径,而使用`write.overwrite().save`方法则能成功保存模型。最后提供了完整的Scala代码示例、Maven配置和提交命令,帮助用户顺利迁移模型存储路径。
|
1月前
|
机器学习/深度学习 算法 决策智能
【机器学习】揭秘深度学习优化算法:加速训练与提升性能
【机器学习】揭秘深度学习优化算法:加速训练与提升性能
|
26天前
|
算法 搜索推荐 Java
java 后端 使用 Graphics2D 制作海报,画echarts图,带工具类,各种细节:如头像切割成圆形,文字换行算法(完美实验success),解决画上文字、图片后不清晰问题
这篇文章介绍了如何使用Java后端技术,结合Graphics2D和Echarts等工具,生成包含个性化信息和图表的海报,并提供了详细的代码实现和GitHub项目链接。
91 0
java 后端 使用 Graphics2D 制作海报,画echarts图,带工具类,各种细节:如头像切割成圆形,文字换行算法(完美实验success),解决画上文字、图片后不清晰问题
|
1月前
|
算法 Java C++
【贪心算法】算法训练 ALGO-1003 礼物(C/C++)
【贪心算法】算法训练 ALGO-1003 礼物(C/C++)
【贪心算法】算法训练 ALGO-1003 礼物(C/C++)
|
26天前
|
算法 Java Linux
java制作海报一:java使用Graphics2D 在图片上写字,文字换行算法详解
这篇文章介绍了如何在Java中使用Graphics2D在图片上绘制文字,并实现自动换行的功能。
66 0
|
1月前
|
算法 C++
蓝桥 算法训练 共线(C++)
蓝桥 算法训练 共线(C++)