• 字母图形_蓝桥杯


    注意:StringBuilder.reverse()会将原字符串反转后并写入原字符串地址,数字转化为字符可以用强制转换

      怎么说,两种理解吧,自我感觉这道题有毒!

      一种理解是,如果是五列的话,那就是“ABCDEDCBABCDE”循环截取上面的一个连续的长度为五的字符串。另一个理解是从“ZYX...CBABC...XYZ”上截取长度为五的字符串

    /**
    问题描述
    利用字母可以组成一些美丽的图形,下面给出了一个例子:
        
        ABCDEFG
        
        BABCDEF
        
        CBABCDE
        
        DCBABCD
        
        EDCBABC
    
    这是一个5行7列的图形,请找出这个图形的规律,并输出一个n行m列的图形。
    
    输入格式
        输入一行,包含两个整数n和m,分别表示你要输出的图形的行数的列数。
    输出格式
        输出n行,每个m个字符,为你的图形。
    样例输入
        5 7
    样例输出
        ABCDEFG
        BABCDEF
        CBABCDE
        DCBABCD
        EDCBABC
    数据规模与约定
        1 <= n, m <= 26。
     */
    package jiChuLianXi;
    
    import java.util.Scanner;
    
    public class LetterFig {
    
    //    public static void main(String[] args) {
    //        // TODO Auto-generated method stub
    //        Scanner in = new Scanner(System.in);
    //        int n = in.nextInt(), m = in.nextInt();
    //        String constStr = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
    //        StringBuilder str = new StringBuilder(constStr.substring(0, m));
    //        StringBuilder s = new StringBuilder(str.toString());
    //        s.append(str.reverse().substring(1));
    //        s.append(str.reverse().substring(1));
    ////        System.out.println(s.length()-m);
    //        int sumLines = s.length()-m;
    //        for(int j=0; j<n; j++){
    ////            System.out.println(":" + (sumLines-j%sumLines) + " " + (sumLines-j%sumLines+m));
    //            System.out.println(s.substring(sumLines-j%sumLines, sumLines-j%sumLines+m));
    //        }
    //        in.close();
    //    }
        public static void main(String[] args) {
            Scanner sc=  new Scanner(System.in);
            int n = sc.nextInt();//接收行数
            int m = sc.nextInt();//接收列数 
            //将A-Z放入a[]中
            int[] a = new int[26];
            char s = 'A';
            for(int i=0;i<26;i++) { 
                a[i] = s+i;
            }
            //循环
            for(int i=0;i<n;i++) {
                for(int j=i;j>=i-m+1&&j>-1;j--) {
                    System.out.print((char)a[j]);
                }
                for(int k=1;k<=m-i-1;k++) {
                    System.out.print((char)a[k]);//数字转化为字符+
                }
                System.out.println();
            }
    }}
    /**
    import java.util.Scanner;
    
    public class Main {
    
        public static void main(String[] args) {
            Scanner sc=  new Scanner(System.in);
            int n = sc.nextInt();//接收行数
            int m = sc.nextInt();//接收列数 
            //将A-Z放入a[]中
            int[] a = new int[26];
            char s = 'A';
            for(int i=0;i<26;i++) { 
                a[i] = s+i;
            }
            //循环
            for(int i=0;i<n;i++) {
                for(int j=i;j>=i-m+1&&j>-1;j--) {
                    System.out.print((char)a[j]);
                }
                for(int k=1;k<=m-i-1;k++) {
                    System.out.print((char)a[k]);//数字转化为字符
                }
                System.out.println();
            }
            
        }
    }
     */
  • 相关阅读:
    工程师的十层楼,上
    工程师的十层楼 (下)
    2011CCTV中国经济年度人物评选结果揭晓
    IT行业程序员薪水差距之大的原因是什么
    单片机C应用开发班
    【分享】对输入子系统分析总结
    P6156 简单题 题解
    P3911 最小公倍数之和 题解
    dp 做题记录
    UVA12298 Super Poker II 题解
  • 原文地址:https://www.cnblogs.com/LieYanAnYing/p/12185825.html
Copyright © 2020-2023  润新知