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);
        }
    }
}
相关推荐
呆呆小雅几秒前
C#关键字volatile
java·redis·c#
დ旧言~几秒前
专题八:背包问题
算法·leetcode·动态规划·推荐算法
Monly21几秒前
Java(若依):修改Tomcat的版本
java·开发语言·tomcat
Ttang233 分钟前
Tomcat原理(6)——tomcat完整实现
java·tomcat
钱多多_qdd14 分钟前
spring cache源码解析(四)——从@EnableCaching开始来阅读源码
java·spring boot·spring
waicsdn_haha16 分钟前
Java/JDK下载、安装及环境配置超详细教程【Windows10、macOS和Linux图文详解】
java·运维·服务器·开发语言·windows·后端·jdk
_WndProc18 分钟前
C++ 日志输出
开发语言·c++·算法
Q_192849990626 分钟前
基于Spring Boot的摄影器材租赁回收系统
java·spring boot·后端
Code_流苏28 分钟前
VSCode搭建Java开发环境 2024保姆级安装教程(Java环境搭建+VSCode安装+运行测试+背景图设置)
java·ide·vscode·搭建·java开发环境
努力学习编程的伍大侠31 分钟前
基础排序算法
数据结构·c++·算法