算法---背包问题

算法—背包问题

参考:趣学算法

代码:

typedef struct three {
	float w;
	float v;
	float p;
}three;
#define elemType three
int quickSort1(elemType a[], int l, int h) {//快速排序
	int i = l, j = h;
	elemType p1 = a[i];
	while (i < j) {
		while (i<j&&a[j].p>=p1.p) {//从右往左遍历查找比p1更小的元素
			j--;
		}
		if (i < j) {
			a[i++] = a[j];
		}
		while (i < j&&a[i].p < p1.p) {//从左往右遍历查找比p1更大的元素
			i++;
		}
		if (i < j) {
			a[j--] = a[i];
		}
	}
	a[i] = p1;//分界的值,左边小于等于p1,右边大于p1
	return  i;
}
void fenZhi1(elemType a[], int l, int h) {//分治
	if (l < h) {
		int mid = quickSort1(a, l, h);//以mid为分界线,进行分治,然后递归下去排序
		fenZhi1(a, l, mid - 1);
		fenZhi1(a, mid + 1, h);
	}
}
#include <stdio.h>
#include <stdlib.h>
#include"quickSort1.h"
int main() {
	elemType a[100];
	int num,i=0;
	scanf_s("%d", &num);
	while (i<num) {
		scanf_s("%f%f", &a[i].w,&a[i].v);
		a[i].p = a[i].v / a[i].w;
		i++;
	}
	fenZhi1(a, 0, num-1);//调动分治策略实现所有趟快速排序,而不是调用快速排序一趟进排序
	for (i = 0; i < num; i++) {
		printf("%f %f %f\n", a[i].w, a[i].v, a[i].p);
	}
	float sum = 0.0,maxValue=0.0,acceptWeight;
	scanf_s("%f", &acceptWeight);
	for (i = num-1; i>=0; i--) {
		if (sum + a[i].w <= acceptWeight) {
			sum += a[i].w;
			maxValue += a[i].v;
		}
		else {
			maxValue += (acceptWeight - sum)*a[i].p;
			sum += (acceptWeight - sum);//装满 
			break;
		}
	}
	printf("背包问题获得的最大值:%f\n", maxValue);
	system("pause");
	return 0;
}

测试截图:

请添加图片描述

时间复杂度O(nlogn),空间复杂度O(n)

彩蛋:不可分的0-1问题如何寻找最优值??

动态规划!!!

如果存在什么问题,欢迎批评指正!谢谢!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

fighting的码农(zg)-GPT

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值