算法设计与分析之动态规划

#include<stdlib.h>
void main()
{
int f1=1;
int f2=1;
int i;
for (i=0;i<10;i++)
{
printf("%d %d",f1,f2);
f1=f1+f2;
f2=f2+f1;
}
system("pause");
}

用数组实现斐波那契函数:

#include <stdio.h>
#include <stdio.h>
int main()
{
int arr[20]={1,1};
int i=0;
for(i=2;i<20;i++)
{
arr[i]=arr[i-1]+arr[i-2];
}
for(i=0;i<20;i++)
{
printf("%10d",arr[i]);
}
system("pause");
return 0;}

递归实现斐波那契函数

#include<stdio.h>
int Fib(int n)
{
if(n<0)
printf("n<0,data error\n");
else if(n==1 || n==2)
	return 1;
else{
return Fib(n-1)+Fib(n-2);}
return 0;}
int main(){
int n,ret=0;
printf("请输入下标:\n");
scanf("%d",&n);
ret=Fib(n);
printf("递归:the %d fib is %d\n",n,ret);
return 0;}	

递归调用Fib(n)采用自顶向下的执行过程
存在大量的重复计算,例如求Fib(5)的过程,存在两次重复计算Fib(3)值的情况:
在这里插入图片描述

背包问题

#include<stdio.h>
int V[200][200];//前i个物品装入容量为j的背包中获得的最大价值
int max(int a,int b)
{ if(a>=b)
return a;
else return b;}

int KnapSack(int n,int w[],int v[],int x[],int C)
{int i,j;//填表,其中第一行和第一列全为0
for(i=0;i<=n;i++)
V[i][0]=0;
for(j=0;j<=C;j++)
V[0][j]=0;
for(i=1;i<=n;i++)
{printf("%d  %d  %d  ",i,w[i-1],v[i-1]);
for(j=1;j<=C;j++)
{if(j<w[i-1]){
V[i][j]=V[i-1][j];

printf("[%d][%d]=%2d  ",i,j,V[i][j]);}
 else{V[i][j]=max(V[i-1][j],V[i-1][j-w[i-1]]+v[i-1]);
printf("[%d][%d]=%2d  ",i,j,V[i][j]);}  }
printf("\n");  }//判断哪些物品被选中
j=C;
 for(i=n;i>=1;i--)
 { if(V[i][j]>V[i-1][j])
 { x[i]=1;
j=j-w[i-1];}

 else
 x[i]=0;}
printf("选中的物品是:\n");
for(i=1;i<=n;i++)
 printf("%d ",x[i]);
 printf("\n");
 return V[n][C];}
void main(){
 int s;//获得的最大价值
int w[15];//物品的重量
int v[15];//物品的价值
int x[15];//物品的选取状态
int n,i;
int C;//背包最大容量
n=5;
printf("请输入背包的最大容量:\n");
scanf("%d",&C);
printf("输入物品数:\n");
scanf("%d",&n);
printf("请分别输入物品的重量:\n");

for(i=0;i<n;i++)
scanf("%d",&w[i]);
printf("请分别输入物品的价值:\n");
for(i=0;i<n;i++)
 scanf("%d",&v[i]);
s=KnapSack(n,w,v,x,C);
printf("最大物品价值为:\n");
printf("%d\n",s);}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值