实用算法的分析与程序设计——贪心算法(包含实例,代码)

包含删数问题,0-1背包和部分背包问题

贪心法也是从问题的某一个初始解出发,向给定的目标递推,但不同的是,推进的每一步不是依据某一固定的递推式,而是做一个当时看似最佳的贪心选择,不断地将问题实例归纳为更小的相似的子问题,并期望通过所做的局部最优选择产生出一个全局最优解。

这种选择未必能得出全局最优解,在下面的实例中可得到全局最优。

注意:编写这几个程序的过程发现在linux gcc编译的程序数组越界不会提示错误,也不警告,只是后面的变量参数都为0

删数问题

键盘输入一个高精度的正整数N,去掉其中任意S个数字后剩下的数字按原左右次序组成一个新的正整数,编程对给定的N和S,寻找一种方案使得剩下的数字组成的新数最小 输出应包括所去掉的数字的位置和组成的新的正整数(N不超过240位) 输入数据均不需判错

算法分析
这里写图片描述
代码如下

/*
 * =====================================================================================
 *
 *       Filename:  delete.cc
 *
 *    Description: 键盘输入一个高精度的正整数N,去掉其中任意S个数字后剩下的数字按原左右次序组成一个新的正整数,编程对给定的N和S,寻找一种方案使得剩下的数字组成的新数最小
 *         输出应包括所去掉的数字的位置和组成的新的正整数(N不超过240位)
 *         输入数据均不需判错
 *
 *        Version:  1.0
 *        Created:  05/08/15 09:25:29
 *       Revision:  none
 *       Compiler:  gcc
 *
 *         Author:  xiu, 
 *   Organization:  
 *
 * =====================================================================================
 */

#include<iostream>
#include<string>

#define SUM 256
usin
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值