weixin_55022867
恆语
2021-04-28 20:45
采纳率: 100%
浏览 34
已采纳

求大佬们看看,这道题怎么做

用Java实现

 

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

4条回答 默认 最新

  • software7503
    已采纳

        public static void main(String[] args) {
            /*
             * 打印菱形
             */
            int line;// 行数,单数
            int star;// 每行的*数量
            int space;// 每行左边的空格数
            int mid;// 中间的行号

            int i, j;
            System.out.println("请输入行数(单数):");
            Scanner in = new Scanner(System.in);
            line = in.nextInt();
            mid = line / 2 + 1;
            // 打印上半部分
            for (i = 1; i <= mid; i++) {
                star = i * 2 - 1;// 第i行的*数
                space = (line - star) / 2; // 第i行左边的空格数
                for (j = 0; j < space; j++) {
                    System.out.print(" ");
                }
                for (j = 1; j <= star; j++) {
                    System.out.print("*");
                }
                System.out.println("");// 换行

            }
            // 打印下半部分
            for (i = mid - 1; i >= 1; i--) {
                star = i * 2 - 1;// 第i行的*数
                space = (line - star) / 2; // 第i行左边的空格数
                for (j = 0; j < space; j++) {
                    System.out.print(" ");
                }
                for (j = 1; j <= star; j++) {
                    System.out.print("*");
                }
                System.out.println(""); // 换行

            }
        }

    点赞 评论
  • technologist_32
    CSDN专家-Time 2021-04-28 20:46

    这个很简单

    public class Demo {
        public static void main(String []args) {
    
            int max = 5;
    
            for (int i = 1; i < max * 2; i ++) {
                if (i <= max) {
                    for (int j = 1; j < i * 2; j ++) {
                        if (j <= i) {
                            System.out.print(j);
                        }   
                        else {
                            System.out.print(i - j + i); 
                        }   
                    }   
                }   
                else {
                    int tmp = (max + max - i );
                    for (int j = 1; j < tmp * 2; j ++) {
                        if (j <= tmp) {
                            System.out.print(j);
                        }   
                        else {
                            System.out.print(tmp - j + tmp);
                        }   
                    }   
                }   
                System.out.println();
            }   
    
        }   
    }
    点赞 评论
  • QA_Assistant
    有问必答小助手 2021-04-29 09:53

    您好,我是有问必答小助手,您的问题已经有小伙伴解答了,您看下是否解决,可以追评进行沟通哦~

    如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

    ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632

    点赞 评论
  • QA_Assistant
    有问必答小助手 2021-04-29 19:20

    非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!

    速戳参与调研>>>https://t.csdnimg.cn/Kf0y

    点赞 评论

相关推荐