java经典算法-day16

举报
喵手 发表于 2024/09/30 22:50:45 2024/09/30
【摘要】 哈喽,各位小伙伴们好,我是喵手。一、前言正值金三银四好时节,又到了刷题月。xdm,有空的欢迎一起呀。无论你是挤公交还是坐地铁时间,随时随地皆可刷...你可以不用实操,你只需要看题思考,完后有空coding就好呀。接下来我要开启我的刷题之旅啦,喜欢的小伙伴欢迎点赞关注哦。二、题目描述:题目1:打印出杨辉三角形(要求打印出10行如下图)。11 11 2 11 3 3 11 4 6 4 11 5 ...


哈喽,各位小伙伴们好,我是喵手。

一、前言

正值金三银四好时节,又到了刷题月。xdm,有空的欢迎一起呀。无论你是挤公交还是坐地铁时间,随时随地皆可刷...你可以不用实操,你只需要看题思考,完后有空coding就好呀。接下来我要开启我的刷题之旅啦,喜欢的小伙伴欢迎点赞关注哦。

二、题目描述:

题目1:

打印出杨辉三角形(要求打印出10行如下图)。
11 11 2 11 3 3 11 4 6 4 11 5 10 10 5 1

题目2:

输入3个数a,b,c,按大小顺序输出。

三、思路分析:

题1分析:

       这题其实就是找规律,先看成一个二维数组,只要是nums[i][j]中的i = j 或 j=0,i为任意值,两种情况展示1;接着就是从i=2开始,中间的值都有一个规律,那就是nums[i][j] = nums[i-1][j-1]+nums[i-1][j];只要你把握好这两种情况,依次将二维数组添加好,最后再进行打印输出即可。

题2分析:

这题其实就比较简单。

思路一:

  • 你只需要比较三次,然后每次比较完都进行数的交换,一样可以得出3个数的排序顺序。也就是两两比较,所谓的枚举法。

思路二:

  • 思路也可以换成for循环遍历。无非就是比较几个数,然后第一层控制比较总的次数,一个冒泡排序即可得出。就是利用双从for循环进行排序对比。

思路三:

  • 就是利用Arrays提供的sort()排序方法,哈哈哈,投机取巧,图省事。

四、算法实现:

题1AC代码:

/**
 * 杨辉三角
 */
public static int[][] yhsj(int n) {

    int[][] nums = new int[n][n];

    //先把i = j 或 j=0;值为1的先给进行添加
    for (int i = 0; i < n; i++) {
        nums[i][i] = 1;
        nums[i][0] = 1;
    }

    //从i>=2开始,规律nums[i][j] = nums[i-1][j-1]+nums[i-1][j] 进行赋值
    for (int i = 2; i < n; i++) {
        for (int j = 1; j <= i - 1; j++) {
            nums[i][j] = nums[i - 1][j - 1] + nums[i - 1][j];
        }
    }
    return nums;
}

题2AC代码:

public static int[] compareNums(int[] nums) {

    //两两比较
    if (nums[0] > nums[1]) {
        int temp = nums[0];
        nums[0] = nums[1];
        nums[1] = temp;
    }
    if (nums[0] > nums[2]) {
        int temp = nums[0];
        nums[0] = nums[2];
        nums[2] = temp;
    }
    if (nums[1] > nums[2]) {
        int temp = nums[1];
        nums[1] = nums[2];
        nums[2] = temp;
    }
    return nums;
}

五、总结:

综上,第一道题其实是很经典的题,还记得大学课本上就有这道题的变种题,比如打印是等边三角形形状的,这道是直角三角形形状的杨辉三角,其实思路都是一样,就是找规律,然后用代码表述规律出来即可。第二道就没啥好讲的,三个数要比较大小,最简单的就是两两比较,然而我还提供了别的思路,供大家参考。

如果你有更好的解题思路或者想法,欢迎评论区留言告诉我哦,喵手感激不尽。

六、文末:

好啦,以上就是我这期的全部内容,如果有任何疑问,欢迎下方留言哦,咱们下期见。

... ...
学习不分先后,知识不分多少;事无巨细,当以虚心求教;三人行,必有我师焉!!!

wished for you successed !!!

---------------------------------------------------------------------

⭐️若喜欢我,就请关注我叭。

⭐️若对您有用,就请点赞叭。

⭐️若有疑问,就请评论留言告诉我叭。

---------------------------------------------------------------------

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。