贪心算法-背包问题

cs 复制代码
#include<stdio.h>
#define N 5 //物品数量(总类) 
#define W 100 //容量 
int v_temp[N+1], w_temp[N+1]; // 物品价值数组,物品容量数组
double vw_temp[N+1];//单位物品价值容量数组
double answer[N+1] = {0};//解方案数组 
void show(int v[],int w[],double vw[])
{
	int i;
	for(i = 1;i<=N;i++){
		printf("%d  ",v[i]);
	}
	printf("\n");
	for(i = 1;i<=N;i++){
	    printf("%d  ",w[i]);
	}
	printf("\n");
		for(i = 1;i<=N;i++){
		printf("%.1f ",vw[i]);
	}
	printf("\n");
}
void merge_sort(int v[],int w[],double vw[],int l,int r)
{
	if(l>=r)
	{
		return ;
	}
	int mid = (l+r)/2;
	merge_sort(v,w,vw,l,mid);
	merge_sort(v,w,vw,mid+1,r);
	int i = l,j = mid+1,k = 1;
	while(i<=mid && j<=r)
	{
		if(vw[i] > vw[j])
		{
			vw_temp[k] = vw[i];
			v_temp[k] = v[i];
			w_temp[k] = w[i];
			k++,i++;
		}
		else
		{
			vw_temp[k] = vw[j];
			v_temp[k] = v[j];
			w_temp[k] = w[j];
			k++,j++;
		}
	}
	while(i<=mid)
	{
		vw_temp[k] = vw[i];
		v_temp[k] = v[i];
		w_temp[k] = w[i];
		k++,i++;
	}
	while(j<=r)
	{
		vw_temp[k] = vw[j];
		v_temp[k] = v[j];
		w_temp[k] = w[j];
		k++,j++;
	}
	for(i = l,j= 1;i<=r;i++,j++)
	{
		vw[i] = vw_temp[j];
		v[i] = v_temp[j];
		w[i] = w_temp[j];
	}
}
double max_value(int v[],int w[],double vw[])
{
	double result = 0.0;
	int i,w_temp = W;
	for(i = 1;i<=N;i++)
	{
		if(w_temp>w[i])
		{
			answer[i] = 1;
			result = result+v[i];
			w_temp = w_temp-w[i];
		}
		else
		{
			break;
		}
	}
	if(w_temp>0 && i<=N)
	{
		answer[i] = (double)w_temp/w[i];
		result = result + w_temp*vw[i];
	}
	return result;
}
int main()
{
	int v[] = {0,20,65,30,40,60};//物品价值数组 
	int w[] = {0,10,30,20,40,50};//物品容量数组
	double vw[N+1] = {0};
	int i;
	for(i = 1;i<=N;i++)
	{
		vw[i] = (double)v[i]/w[i];
	} 
	printf("排序前\n");
	show(v,w,vw);
	
	printf("排序后\n");
	merge_sort(v,w,vw,1,N);//归并排序 
	show(v,w,vw);
	
	double result = max_value(v,w,vw); 
	printf("result = %.1f\n",result);
	
	printf("解方案结果为:\n");
	for(i = 1;i<=N;i++)
	{
		printf("%.1f ",answer[i]);
	}
	return 0;
}
相关推荐
大雨淅淅1 小时前
【机器人】ROS2 机械臂控制(MoveIt2)从入门到实战
人工智能·python·神经网络·学习·算法·机器学习·机器人
智者知已应修善业2 小时前
【51单片机0.1秒计时到21.0时点亮LED】2024-1-5
c++·经验分享·笔记·算法·51单片机
csdn_aspnet2 小时前
C# 使用linq给List某个属性值赋值
c#·list·linq
apcipot_rain2 小时前
计科八股20260606——二叉树、PCA、图深度学习、进程上下文、C语言预编译、文件读写、单精度浮点数
c语言·数据结构·算法·pca·图神经网络
scx_link2 小时前
逻辑回归的总结
算法·机器学习·逻辑回归
沐籽李2 小时前
Proteina-Complexa:NVIDIA 如何把蛋白 Binder 设计推进到全原子生成时代?
大数据·人工智能·算法·英伟达·蛋白质生成
落羽的落羽2 小时前
【项目】JsonRpc框架——开发实现2(业务层)
linux·数据结构·c++·人工智能·算法·json·动态规划
h_a_o777oah2 小时前
2026 蓝桥杯软件 C++B组 国赛比赛经历及备赛建议
c++·经验分享·算法·蓝桥杯
赵谨言2 小时前
基于C#的在线编码与自动化测试全栈Web平台的设计与实现
开发语言·前端·c#