求背包问题所有解(C++实现)

这是我学习数据结构时的一道上机作业,那时还没养成写注释的习惯,所以各位得受点苦了。

只是简易背包问题。

代码:

展开
  1 // 背包问题所有解
  2 // 作者:王锦 
  3 // 邮箱:jinksw@vip.qq.com
  4 
  5 #include "stdafx.h"
  6 #include <iostream>
  7 #include <stack>
  8 #include <list>
  9 using namespace std;
 10 
 11 class BagProblemSolver
 12 {
 13 private:
 14     int *stuffWeight;
 15     int s;
 16     int n;
 17     list<list<int>*> allResultHolder;//存放所有解
 18     void insertResultToList(stack<int> bagStack);
 19 public:
 20     BagProblemSolver(int s,int n,int *stuffWeight)
 21     {
 22         this->s = s;
 23         this->n = n;
 24         this->stuffWeight = new int[n];
 25         for(int i = 0;i < n;++i)
 26             this->stuffWeight[i] = stuffWeight[i];
 27     }
 28     ~BagProblemSolver()
 29     {
 30         delete[] stuffWeight;
 31     }
 32     list<list<int>*> getAllResult();
 33 };
 34 
 35 list<list<int>*> BagProblemSolver::getAllResult()
 36 {
 37     if(s <= 0)
 38         return allResultHolder;
 39     int currentWeight = 0;
 40     stack<int> indexStack;
 41     int i = 0;
 42     do
 43     {
 44         while(currentWeight < s && i < n)
 45         {
 46             if(currentWeight + stuffWeight[i] <= s)
 47             {
 48                 indexStack.push(i);
 49                 currentWeight += stuffWeight[i];
 50             }
 51             i++;
 52         }
 53         if(currentWeight == s)
 54         {
 55             insertResultToList(indexStack);
 56             i = indexStack.top();
 57             indexStack.pop();
 58             currentWeight -= stuffWeight[i];
 59             i++;
 60         }
 61         else if(!indexStack.empty())
 62         {
 63             i = indexStack.top();
 64             indexStack.pop();
 65             currentWeight -= stuffWeight[i];
 66             i++;
 67         }
 68     }while(!indexStack.empty() || i < n);
 69     return allResultHolder;
 70 }
 71 
 72 
 73 
 74 void BagProblemSolver::insertResultToList(stack<int> bagStack)
 75 {
 76     stack<int> tempStack;//用于将解以正序存入list
 77     while(!bagStack.empty())
 78     {
 79         tempStack.push(bagStack.top());
 80         bagStack.pop();
 81     }
 82     list<int> * resultList = new list<int>();
 83     while(!tempStack.empty())
 84     {
 85         resultList->push_back(stuffWeight[tempStack.top()]);
 86         tempStack.pop();
 87     }
 88     allResultHolder.push_back(resultList);
 89 }
 90 
 91 int _tmain(int argc, _TCHAR* argv[])
 92 {
 93     cout << "请输入背包可以放入的物品重量.(输入q退出)" << endl;
 94     char c;
 95     cin >> c;
 96     while(c != 'q')
 97     {
 98         cin.putback(c);
 99         int s = 0;
100         cin >> s;//背包可以放入的物品重量
101         cout << "请输入物品数量." << endl;
102         int n = 0;//物品数量
103         cin >> n;
104         int *stuffWeight= new int[n];
105         cout << "请分别输入" << n << "个物品重量." << endl;
106         for(int i = 0;i < n;++i)
107             cin >> stuffWeight[i];
108         BagProblemSolver test(s,n,stuffWeight);
109         list<list<int>*> ls = test.getAllResult();
110         cout << "背包容量(" << s << "),有(" << n << ")个物品,";
111         cout << "质量分别为(";
112         for(int i = 0; i < n;++i)
113         {
114             cout << stuffWeight[i];
115             if(i != n - 1)
116                 cout << ",";
117         }    
118         cout << ")" << endl;
119         if(ls.empty())
120         {
121             cout << "此问题无解!" << endl;
122         }
123         else
124         {
125             cout << "所有解为:" << endl;
126             while(!ls.empty())
127             {
128                 list<int> *temp = ls.front();
129                 ls.pop_front();
130                 while(!temp->empty())
131                 {
132                     cout << temp->front() << " ";
133                     temp->pop_front();
134                 }
135                 cout << endl;
136                 delete temp;
137             }
138         }
139         cout << "请输入背包可以放入的物品重量.(输入q退出)" << endl;
140         cin >> c;
141     }
142 }

 

 

转载于:https://www.cnblogs.com/jinks/archive/2013/04/26/3044930.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/461132.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

I2C子系统详解3——I2C总线驱动层代码分析

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 一、前言 由I2C总线设备的驱动框架可知&#xff0c;I2C总线设备的驱动框架涉及的文件如下&#xff1a; &#xff08;1&#xff09;I2C设备驱动层相关的文件 x210开发板的电容触摸屏gslX680采用I2C接…

java join 异常_Java:守护进程:thread.join()没有完成,当在一个线程中抛出异常时...

我写了一个Java守护进程(一个实现守护进程和Runnable的类)&#xff0c;现在我遇到了以下问题&#xff1a;在init()中&#xff0c;我创建了一个新线程 . Thread thread new Thread(this); 在start()中我启动新线程 . thread.start() . 在运行中我做了很多不同的事情......然后发…

硬链接与符号链接的比较?

今天就说说硬链接&#xff08;实体链接&#xff09;与符号链接&#xff08;类似Windows的快捷方式&#xff09;的不同?首先我们应知道&#xff1a;每个档案都会占用一个inode ,档案内容由 inode记录来指向;想要读取该档案&#xff0c;必须要经过目录记录的文件名来指向正确的i…

JAVA--自制斐波那契数列输出

累了&#xff0c;写点简单的。 1 public class hello {2 3 /**4 * param args5 */6 public static void main(String[] args) {7 int Fabnum 10;8 int sum 0;9 System.out.print("Serial:\t"); 10 for(int i 1…

I2C子系统详解4——I2C设备驱动层代码分析

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 一、前言 由I2C总线设备的驱动框架可知&#xff0c;I2C总线设备的驱动框架涉及的文件如下&#xff1a; &#xff08;1&#xff09;I2C设备驱动层相关的文件 x210开发板的电容触摸屏gslX680采用I2C接…

golang java rpc_golang两种调用rpc的方法

本文实例讲述了golang两种调用rpc的方法。分享给大家供大家参考&#xff0c;具体如下&#xff1a;golang的rpc有两种方法进行调用&#xff0c;一种是rpc例子中给的&#xff1a;package mainimport ("net/rpc""net/http""log""net"&quo…

9、C语言 —— 指针的用处

为什么80%的码农都做不了架构师&#xff1f;>>> 1、用函数实现两个数的交换 ‍‍在没用函数之前&#xff0c;可以这样实现‍‍#include <stdio.h>int main() {int a 3;int b 7;int c;printf("交换前&#xff0c;a%d&#xff0c;b%d\n", a, b); …

内核中的竞争状态和互斥(简述)

以下内容源于朱有鹏《物联网大讲堂》课程的学习&#xff0c;如有侵权&#xff0c;请告知删除。 一、概念 &#xff08;1&#xff09;竞争状态&#xff08;简称竟态&#xff09;&#xff1b; &#xff08;2&#xff09;临界段&#xff08;某一段代码&#xff0c;该代码有可能…

MenuetOS

MenuetOS由芬兰人Ville Turjanmaa开发&#xff0c;是一个操作系统&#xff0c;用于和IBM PC兼容的电脑。 它由汇编语言写成&#xff0c;可以存入一只1.44MB的软盘中。 Menuet OS 的32位版本Menuet32使用GNU通用公共许可证发放&#xff0c;但64位版本Menuet64使用自己的协议发放…

php是一种,PHP是一种什么型的语言:()

案例分析一&#xff1a;假定CPU的主频是500MHz。硬盘采用DMA方式进行数据传送&#xff0c;其数据传输率为4MB/s, 每次DMA传输的数据量为8KB, 要求没有任何数据传输被错过。如果CPU在DMA初始化设置和启动硬盘操作等方面用了1000个时钟周期&#xff0c;并且在DMA传送完成后的中断…

java动态代理二cglib

2019独角兽企业重金招聘Python工程师标准>>> java动态代理 转载于:https://my.oschina.net/u/1430510/blog/290215

spring心得6--自动装配知识点讲解及案例分析

1.自动装配&#xff1a; spring3.2以上版本有四种自动装配类型&#xff1a; 1&#xff09;.byName:寻找和属性名相同的bean,若找不到&#xff0c;则装不上。 2&#xff09;.byType:寻找和属性类型相同的bean,找不到,装不上,找到多个抛异常。 3&#xff09;.constructor:按照参数…

中断的上下半部

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 前言 因为输入类设备的输入都是异步事件&#xff0c;因此一般使用中断来处理和响应。 中断处理程序处于中断上下文中&#xff0c;不能和用户空间数据交互&#xff08;不能使用copy_to(from)_usr函数…

arrayPointer

1,分别使用指针加减 int wages[2] {100000000,20000000}; int *pw wages or int *pw &wages[0] 表示指针指向数组的首地址; pw表示地址,*pw表示取值,new分配的动态数组时 指针名称当数组名称使用eg pw[0],pw[2]分别表示指向数组wages的2个数组的元素值; 我们已知pw表示此…

php抓取动态数据,php+ajax实现无刷新动态加载数据技术

我们浏览有些网页的时候&#xff0c;当拉动浏览器的滚动条时到页底时&#xff0c;页面会继续自动加载更多内容供用户浏览。这种技术我暂且称它为滚屏加载技术。我们发现很多网站用到这种技术&#xff0c;必应图片搜索、新浪微博、QQ空间等将该技术应用得淋漓尽致。滚屏加载技术…

图片播放器小项目(详解)

以下内容源于朱有鹏《物联网大讲堂》课程的学习整理&#xff0c;如有侵权&#xff0c;请告知删除。一、开始动手写代码 1、Makefile介绍 &#xff08;1&#xff09;这是一个通用的项目管理的Makefile体系&#xff0c;自己写的&#xff08;有子文件夹组织的&#xff09;项目可以…

基于linux-2.6.32.2的servfox移植

说明&#xff1a;这篇文章是本人在做基于web客户端的远程监控系统课题期间&#xff0c;在移植servfox应用服务程序费了很大周折&#xff0c;所以写下的。 只是介绍了基于arm的servfox移植【因为其他部分的移植没有遇到过错误】 前言&#xff1a; 如何移植基于linux的USB摄像头驱…

Telnet远程访问思科交换机、路由器

一、实验目的Telnet远程访问思科交换机、路由器二、实验拓扑三、实验步骤1、PC1远程管理S11&#xff09;配置交换机的管理IPS1(config)#int vlan 1S1(config-if)#ip add 192.168.1.100 255.255.255.0S1(config-if)#no shu2&#xff09;开启S1的telnet远程管理服务S1(config)#li…

php redis 队列,Redis 实现队列

## Redis 实现队列Redis 实现队列场景说明&#xff1a;用于处理比较耗时的请求&#xff0c;例如批量发送邮件&#xff0c;如果直接在网页触发执行发送&#xff0c;程序会出现超时高并发场景&#xff0c;当某个时刻请求瞬间增加时&#xff0c;可以把请求写入到队列&#xff0c;后…

offsetTop测试见解

offsetTop一开始以为只要容器内div的top定位为负就行&#xff0c;结果今天刚做了个demo&#xff0c;发现好像不是那么回事&#xff0c;于是经过各种测试&#xff0c;得出了一些结论&#xff0c;结论看demo <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" &qu…