POJ 1014 Dividing 背包

本文探讨了二进制优化方法,通过将物体分解为2的倍数加位数的形式,实现从1到特定数值的所有组合可能性。该方法与背包问题解决策略相似,能够有效地确定是否能通过组合给定的元素达到目标值。

二进制优化,事实上是物体的分解问题。

就是比方一个物体有数量限制,比方是13,那么就须要把这个物体分解为1。 2, 4, 6

假设这个物体有数量为25,那么就分解为1, 2, 4。 8。 10

看出规律吗,就是分成2的倍数加上位数,比方6 = 13 - 1 - 2 - 4, 10 = 25 - 1 - 2 - 4 - 8。呵呵,为什么这么分解?

由于这样分解之后就能够组合成全部1到13的数。为25的时候能够组合成全部1到25的数啦。

就是这么一个分解物体。最后组合的问题。

不明确?

给多几个数字组合:

31分解 1, 2, 4, 8, 16

32分解1,2,4, 8, 16, 1

33分解1,2,4,8,16,2

如此分解的。

想通了,就和一般背包问题一样做法了。

#include <stdio.h>
#include <vector>
using std::vector;

const int SIZE = 7;
int N[SIZE];
bool findPartition()
{
	int sum = 0;
	for (int i = 1; i < SIZE; i++)
		sum += i * N[i];
	if (sum & 1) return false;

	int half = sum >> 1;
	vector<bool> part(half+1);
	part[0] = true;

	for (int i = 1; i < SIZE; i++)
	{
		int k = 1;
		for ( ; (k<<1) <= N[i]; k <<= 1)
		{//例:13分解为1,2,4,6能够组合为1到13个物品。故此考虑了全部情况了
			for (int j = half; j >= k*i; j--)
			{
				if (part[j-k*i]) part[j] = true;
			}
		}
		k = N[i] - k + 1;
		for (int j = half; j >= k*i; j--)
		{
			if (part[j-k*i]) part[j] = true;
		}
	}
	return part[half];
}

int main()
{	
	int t = 1;
	while (true)
	{
		int val = 0;
		for (int i = 1; i < SIZE; i++)
		{
			scanf("%d", &N[i]);
			val += N[i];
		}
		if (!val) return 0;
		if (findPartition()) printf("Collection #%d:\nCan be divided.\n\n", t++);
		else printf("Collection #%d:\nCan't be divided.\n\n", t++);
	}
	return 0;
}



转载于:https://www.cnblogs.com/gccbuaa/p/6944985.html

标题基于Python的自主学习系统后端设计与实现AI更换标题第1章引言介绍自主学习系统的研究背景、意义、现状以及本文的研究方法和创新点。1.1研究背景与意义阐述自主学习系统在教育技术领域的重要性和应用价值。1.2国内外研究现状分析国内外在自主学习系统后端技术方面的研究进展。1.3研究方法与创新点概述本文采用Python技术栈的设计方法和系统创新点。第2章相关理论与技术总结自主学习系统后端开发的相关理论和技术基础。2.1自主学习系统理论阐述自主学习系统的定义、特征和理论基础。2.2Python后端技术栈介绍DjangoFlask等Python后端框架及其适用场景。2.3数据库技术讨论关系型和非关系型数据库在系统中的应用方案。第3章系统设计与实现详细介绍自主学习系统后端的设计方案和实现过程。3.1系统架构设计提出基于微服务的系统架构设计方案。3.2核心模块设计详细说明用户管理、学习资源管理、进度跟踪等核心模块设计。3.3关键技术实现阐述个性化推荐算法、学习行为分析等关键技术的实现。第4章系统测试与评估对系统进行功能测试和性能评估。4.1测试环境与方法介绍测试环境配置和采用的测试方法。4.2功能测试结果展示各功能模块的测试结果和问题修复情况。4.3性能评估分析分析系统在高并发等场景下的性能表现。第5章结论与展望总结研究成果并提出未来改进方向。5.1研究结论概括系统设计的主要成果和技术创新。5.2未来展望指出系统局限性并提出后续优化方向。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值