图解算法笔记

本文介绍了二分查找算法在有序数组中的应用,探讨了其时间复杂度,并与旅行商问题进行对比,同时涵盖了选择排序和分治法的基本概念。讨论了如何识别NP完全问题,以及贪心与动态规划在背包问题中的区别,最后涉及最长公共子串和子序列的算法详解。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 二分查找

        输入有序序列(数组),一个数(找的数)

        

package MySearch;

public class BinarySearchDemo {
    public static void main(String[] args) {
        int[] arr = {1,2,3,4,5,6,7,8,9,11};
        int res = binarySearch(arr, 11);
        System.out.println(res);

    }

    public static int binarySearch(int[] arr, int x){

        int left = 0;
        int right = arr.length - 1;

        while (left<=right) {
            int mid = (right+left)/2;   // important

            if (arr[mid] == x) {
                return mid;
            }

            if (x < mid){
                right = mid-1;
            }

            if (x>mid){
                left = mid+1;
            }
        }

        // 还没有找到
        return -1;
    }
}

2. 旅行商问题

        时间复杂度 = O(n!)

        

3. 选择排序

        选择最小(大),加入新数组。

        我的排序算法总结https://blog.csdn.net/weixin_43891234/article/details/121014855?spm=1001.2014.3001.5501https://blog.csdn.net/weixin_43891234/article/details/121014855?spm=1001.2014.3001.5501

4. 分治法

5. NP完全问题

        如何判断是不是NP完全问题

                1. 元素较少时候,运行速度快,元素数量增加,速度变得很慢

                2. 涉及所有组合问题

                3. 不能把问题划分成小问题,必须考虑所有情况

                4. 涉及序列(旅行商问题)

                5. 涉及集合(集合覆盖问题)

                6. 可以转换成4,5两种的问题

6. 贪心和动态规划

        贪心背包问题:可以拿一部分,如一袋米价值100/1g,共20g,可以考虑拿一部分如5g

        DP背包问题:只能选择拿或者不拿,不能只拿一部分

        具体参考算法图解书籍。

7. 最长公共子串,最长公共子序列

        参考书籍

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值