- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
                        查看更多
                        
                    
                算法设计与分析实验指导29234.doc
                    
算法设计与分析实验指导
  
王歧  编实验一:递归与分治
二分查找
合并排序
快速排序
实验二:回溯
0-1背包问题
装载问题
堡垒问题(ZOJ1002)
*翻硬币问题
8皇后问题
素数环问题
迷宫问题
*农场灌溉问题(ZOJ2412)
*求图像的周长(ZOJ1047)
*骨牌矩阵
*字母转换(ZOJ1003)
*踩气球(ZOJ1004)
实验三:搜索
Floodfill
电子老鼠闯迷宫分酒问题实验四:动态规划
最长公共子序列
计算矩阵连乘积
凸多边形的最优三角剖分
防卫导弹
*石子合并
*最小代价子母树
*旅游预算
*皇宫看守
*游戏室问题
*基因问题
*田忌赛马
实验五:贪心与随机算法
背包问题在对线性表的操作中,经常需要查找某一个元素在线性表中的位置。此问题的输入是待查元素x和线性表L,输出为x在L中的位置或者x不在L中的信息。实验二:回溯算法
实验目的:熟练掌握回溯算法
实验内容:回溯算法的几种形式
用回溯算法搜索子集树的一般模式
void search(int m)
{
	if(mn)           //递归结束条件 
		output();      //相应的处理(输出结果)
	else
	{
		a[m]=0;       //设置状态:0表示不要该物品
		search(m+1);   //递归搜索:继续确定下一个物品
		a[m]=1;       //设置状态:1表示要该物品
		search(m+1);   //递归搜索:继续确定下一个物品
	}
}
用回溯算法搜索子集树的一般模式
void search(int m)
{
	if(mn)               //递归结束条件 
		output();          //相应的处理(输出结果)
	else
		for(i=m;i=n;i++)
		{
			swap(m,i);     //交换a[m]和a[i]
			if()
				if(canplace(m))  //如果m处可放置
					search(m+1); //搜索下一层
			swpa(m,i);     //交换a[m]和a[i](换回来)
		}
}
习题
0-1背包问题
在0 / 1背包问题中,需对容量为c 的背包进行装载。从n 个物品中选取装入背包的物品,每件物品i 的重量为wi ,价值为pi 。对于可行的背包装载,背包中物品的总重量不能超过背包的容量,最佳装载是指所装入的物品价值最高。 
   程序如下:
#include stdio.h
void readdata();
void search(int);
void checkmax();
void printresult();
int c=35, n=10;        //c: 背包容量;n:物品数
int w[10], v[10];       //w[i]、v[i]:第i件物品的重量和价值
int a[10], max;        //a数组存放当前解各物品选取情况;max:记录最大价值
                    //a[i]=0表示不选第i件物品,a[i]=1表示选第i件物品
int main()
{
	readdata();       //读入数据
	search(0);        //递归搜索
	printresult();
}
void search(int m)
{
	if(m=n)
		checkmax();   //检查当前解是否是可行解,若是则把它的价值与max比较
	else
	{
		a[m]=0;       //不选第m件物品
		search(m+1);  //递归搜索下一件物品
		a[m]=1;       //不选第m件物品
		search(m+1);  //递归搜索下一件物品
	}
}
void checkmax()
{
	int i, weight=0, value=0;
	for(i=0;in;i++)
	{
		if(a[i]==1)                 //如果选取了该物品
		{
			weight = weight + w[i];  //累加重量
			value = value + v[i];     //累加价值
		}
	}
	if(weight=c)                  //若为可行解
		if(valuemax)              //且价值大于max
			max=value;            //替换max
}
void readdata()
{
	int i;
	for(i=0;in;i++)
		scanf(%d%d,w[i],v[i]);   //读入第i件
                您可能关注的文档
最近下载
- 高一上学期课堂趣味惩罚游戏课件.pptx VIP
- 2025年成都市新津县某国企招聘笔试备考试题及答案详解1套.docx VIP
- 23G409先张法预应力混凝土管桩图集.PDF VIP
- 2025年成都市新津县某国企招聘笔试备考试题及完整答案详解1套.docx VIP
- 老年人体检健康教育讲座.pptx VIP
- 2025年成都市新津县某国企招聘笔试备考试题及答案详解一套.docx VIP
- 广东省机关事业单位工作人员养老保险制度改革政策解读.ppt VIP
- 人卫慕课《走进肺功能》试题答案.pdf VIP
- 康明斯柴油国六后处理系统培训.pptx VIP
- 2025年成都市新津县某国企招聘笔试备考试题及参考答案详解一套.docx VIP
 原创力文档
原创力文档 
                         
                                    

文档评论(0)