算法复习——填空题

这篇博客回顾了四个算法问题:子集生成,全排列生成,最长公共子序列和最大子序和。通过详细解释和示例代码,阐述了如何利用回溯法解决子集生成,如何生成全排列,以及如何运用动态规划求解最长公共子序列和最大子序和的问题。
摘要由CSDN通过智能技术生成

算法复习

算法填空题

子集生成

给定一个正整数集合X={x1,x2, ... , xn}和一个正整数y,设计一个回溯算法求集合x的一个子集Y,使得Y中的元素之和等于y

算法如下:

输入:数组x,解向量p,开始下标from,目标y

输出:true或者false

1.若X[from]等于y,则p[from] = 1,返回ture//找到解

2.若X[from]大于y,则p[from] = 0,返回false//剪枝回溯

3.置p[from] = 1

3.1调用本算法,参数X,p,from+1,y-X[from];

3.2若算法返回true,则找到一组解,返回true

4.置p[from] = 0

4.1调用本算法,参数X,p,from+1,y

4.2若算法返回true,则找到一组解,返回true

代码:

public boolean reverse(int[] X,boolean[] p,int from,int y){
    if(X[from] == y){
        p[from] = true;
        return true;
    }
    if(X[from] > y){
        p[from] = false;
        return fasle;
    }
    p[from] = true;
    if(reverse(X,p,from+1,y-X[from]))
        return true;
    p[from] = false;
    if(reverse(X,p,from+1,y))
        return true;
}

全排列生成

给定一个 没有重复 数字的序列,返回其所有可能的全排列。

算法如下:

全局变量:数组P存放符合条件的结果,对象数组result,存放结果,used Boolean[]数组,判断是否使用过

输入:数组X

输出:无

1:若数组P的长度等于X的长度,则将数组P添加到result数组中

2

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值