java五道基础算法题

常见的算法题,难度从简单到困难,可以用来开拓下思维。

  • 根据年龄,身高,姓名排序,前一个相等就用后一个进行排序

javabean基础类

java 复制代码
package com.gaofeng.demo09;


public class GirlFriend {
    private  String name;
    private  Integer age;
    private Double height;

    public GirlFriend() {
    }

    public GirlFriend(String name, Integer age, Double height) {
        this.name = name;
        this.age = age;
        this.height = height;
    }

    /**
     * 获取
     * @return name
     */
    public String getName() {
        return name;
    }

    /**
     * 设置
     * @param name
     */
    public void setName(String name) {
        this.name = name;
    }

    /**
     * 获取
     * @return age
     */
    public Integer getAge() {
        return age;
    }

    /**
     * 设置
     * @param age
     */
    public void setAge(Integer age) {
        this.age = age;
    }

    /**
     * 获取
     * @return height
     */
    public Double getHeight() {
        return height;
    }

    /**
     * 设置
     * @param height
     */
    public void setHeight(Double height) {
        this.height = height;
    }

    public String toString() {
        return "GirlFriend{name = " + name + ", age = " + age + ", height = " + height + "}";
    }
}
java 复制代码
package com.gaofeng.demo09;

import java.util.Arrays;
import java.util.Comparator;

public class demo01 {
    public static void main(String[] args) {
        //
        GirlFriend gf1 = new GirlFriend("xiaoshishi", 21, 1.67);
        GirlFriend gf2 = new GirlFriend("xiaodandan", 19, 1.70);
        GirlFriend gf3 = new GirlFriend("xiaohuihui", 20, 1.68);

        GirlFriend[] arr = {gf1, gf2, gf3};

        /*Arrays.sort(arr, new Comparator<GirlFriend>() {
            @Override
            public int compare(GirlFriend o1, GirlFriend o2) {
                double i = o1.getAge() - o2.getAge();
                i = i == 0 ? o1.getHeight() - o2.getHeight() : i;
                i = i == 0 ? o1.getName().compareTo(o2.getName()):i;
                if(i > 0){
                    return 1;
                }else if(i < 0){
                    return -1;
                }else{
                    return 0;
                }
            }
        });*/
        Arrays.sort(arr, (o1,o2) -> {
            double i = o1.getAge() - o2.getAge();
            i = i == 0 ? o1.getHeight() - o2.getHeight() : i;
            i = i == 0 ? o1.getName().compareTo(o2.getName()):i;
            if(i > 0){
                return 1;
            }else if(i < 0){
                return -1;
            }else{
                return 0;
            }
        });

        System.out.println(Arrays.toString(arr));
    }
}
  • 斐波拉契数列
java 复制代码
package com.gaofeng.demo09;

import java.util.Arrays;

public class Demo02 {
    public static void main(String[] args) {

        // 从第三个数据开始,是前两个数据的和
        int[] arr = new int[12];
        arr[0] = 1;
        arr[1] = 1;
        /*for (int i = 2; i < arr.length; i++) {
            arr[i] = arr[i - 1] + arr[i - 2];
        }
        System.out.println(Arrays.toString(arr));*/

        int num = fibonacci(12);
        System.out.println(num); // 144
    }

    // 递归解决
    public static int fibonacci(int n) {
        if (n == 1 || n == 2) {
            return 1;
        }
        return fibonacci(n - 1) + fibonacci(n - 2);
    }
}
  • 猴子吃桃问题,猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个,第二天早上又将剩下的桃子吃掉一半,又多吃了一个,直到第10天,只剩下1个,共摘了多少个桃子?
java 复制代码
package com.gaofeng.demo09;

public class Demo03 {
    public static void main(String[] args) {
        // 出口 day == 10    1
        System.out.println(getCount(1));  //1534

    }

    public static int getCount(int day){
        if(day > 10 || day < 1){
            System.out.println("输入错误");
        }
        if(day == 10){
            return 1;
        }else{
            return (getCount(day + 1) + 1)*2;
        }
    }
}
  • 爬楼梯问题,有20阶楼梯,每次只能爬1阶或者2阶,有多少种走法
java 复制代码
package com.gaofeng.demo09;

public class Demo04 {
    public static void main(String[] args) {
        System.out.println(getCount(20));  //10946
    }
    // 爬楼梯

    public static int getCount(int step){
        if(step == 1){
            return 1;
        }else if(step == 2){
            return 2;
        }else{
            return getCount(step - 1) + getCount(step - 2);
        }
    }
}
  • 爬楼梯,有时候可以一个台阶,有时候可以两个台阶,有时候可以三个台阶,总共有20个台阶,有多少种走法
java 复制代码
package com.gaofeng.demo09;

public class Demo05 {
    public static void main(String[] args) {
        int count = getCount(20);
        System.out.println(count); //121415
    }

    // 爬楼梯,有时候可以一个台阶,有时候可以两个台阶,有时候可以三个台阶,总共有20个台阶,有多少种走法
    public static int getCount(int step){
        if(step == 1){
            return 1;
        }else if(step == 2){
            return 2;
        }else if(step == 3){
            return 4;
        }else{
            return getCount(step - 1) + getCount(step - 2) + getCount(step - 3);
        }
    }
}
相关推荐
alphaTao4 分钟前
LeetCode 每日一题 2024/11/18-2024/11/24
算法·leetcode
天天扭码7 分钟前
五天SpringCloud计划——DAY2之单体架构和微服务架构的选择和转换原则
java·spring cloud·微服务·架构
程序猿进阶7 分钟前
堆外内存泄露排查经历
java·jvm·后端·面试·性能优化·oom·内存泄露
FIN技术铺12 分钟前
Spring Boot框架Starter组件整理
java·spring boot·后端
kitesxian13 分钟前
Leetcode448. 找到所有数组中消失的数字(HOT100)+Leetcode139. 单词拆分(HOT100)
数据结构·算法·leetcode
小曲程序19 分钟前
vue3 封装request请求
java·前端·typescript·vue
陈王卜37 分钟前
django+boostrap实现发布博客权限控制
java·前端·django
小码的头发丝、37 分钟前
Spring Boot 注解
java·spring boot
java亮小白199742 分钟前
Spring循环依赖如何解决的?
java·后端·spring
飞滕人生TYF1 小时前
java Queue 详解
java·队列