ChatGPT体验 AI绘画体验
bitset用法示例及优化背包详解
提问人:ppw_crxis 时间:2025-03-03 公开状态:

提问人:ppw_crxis 时间:2025-03-03 公开状态:


`bitset` 是 C++ 标准库中的一个模板类,它提供了一个紧凑的位序列表示,可以用于高效的存储和操作位集合。以下是 `bitset` 的一些基本用法示例和优化背包问题的详解。
### bitset 基本用法示例
#### 1. 定义和初始化
```cpp
#include <bitset>
#include <iostream>
int main() {
// 定义一个长度为10的bitset,默认所有位都是0
std::bitset<10> bs1;
// 定义一个长度为8的bitset,并用字符串初始化
std::bitset<8> bs2("11001010");
// 输出bitset
std::cout << "bs1: " << bs1 << std::endl;
std::cout << "bs2: " << bs2 << std::endl;
return 0;
}
```
#### 2. 访问和修改位
```cpp
// 设置第3位(从0开始计数)
bs1.set(3);
// 重置第3位
bs1.reset(3);
// 切换第3位的状态
bs1.flip(3);
// 检查第3位是否为1
if (bs1.test(3)) {
std::cout << "第3位是1" << std::endl;
} else {
std::cout << "第3位不是1" << std::endl;
}
```
#### 3. 常用操作
```cpp
// 获取bitset中1的个数
int count = bs2.count();
// 检查bitset是否全为0
bool all_zero = bs1.none();
// 检查bitset是否至少有一个位为1
bool any_one = bs2.any();
// 检查bitset是否全为1
bool all_one = bs2.all();
```
### 优化背包问题详解
背包问题是组合优化的一个例子。给定一组物品,每种物品都有自己的重量和价值,目标是选取一部分物品放入背包中,,使得背包内物品的总价值最大,时不超过背包的容量限制。
#### 0-1背包问题
对于0-1背包问题,每个物品只能选择放或不放。以下是使用 `bitset` 优化0-1背包问题的方法:
```cpp
#include <bitset>
#include <vector>
#include <iostream>
// 物品结构体
struct Item {
int weight;
int value;
};
// 使用bitset优化的0-1背包问题
int knapsack(std::vector<Item>& items, int W) {
int n = items.size();
std::vector<int> dp(W + 1, 0);
for (int i = 0; i < n; ++i) {
for (int w = W; w >= items[i].weight; --w) {
dp[w] = std::max(dp[w], dp[w - items[i].weight] + items[i].value);
}
}
return dp[W];
}
int main() {
std::vector<Item> items = {{2, 3}, {3, 4}, {4, 5}, {5, 6}};
int W = 8;
std::cout << "最大价值: " << knapsack(items, W) << std::endl;
return 0;
}
```
在上面的代码中,我们没有直接使用 `bitset`,因为我们使用的是一维数组 `dp` 来存储背包问题的解。但是,如果我们想要进一步优化空间复杂度,我们可以使用 `bitset` 来代替数组。以下是如何使用 `bitset` 来优化空间复杂度的示例:
```cpp
#include <bitset>
#include <vector>
#include <iostream>
// 物品结构体
struct Item {
int weight;
int value;
};
// 使用bitset优化的0-1背包问题
int knapsack(std::vector<Item>& items, int W) {
int n = items.size();
std::bitset<W + 1> dp;
dp.set(0); // 初始化,表示重量为0时的价值为0
for (int i = 0; i < n; ++i) {
// 从后向前更新,防止重复使用同一个物品
for (int w = W - items[i].weight; w >= 0; --w) {
if (dp.test(w)) {
dp.set(w + items[i].weight);
}
}
}
// 找到最大价值
for (int w = W; w >= 0; --w) {
if (dp.test(w)) {
return w; // 这里返回的是重量,如果要返回价值,需要额外的处理
}
}
return 0;
}
int main() {
std::vector<Item> items = {{2, 3}, {3, 4}, {4, 5}, {5, 6}};
int W = 8;
std::cout << "最大重量: " << knapsack(items, W) << std::endl;
return 0;
}
```
在这个示例中,我们使用 `bitset` 来存储每个重量是否可达。`dp.set(w)` 表示重量为 `w` 的背包是可以达到的。我们遍历每个物品,更新 `bitset`,最后找到可以达到的最大重量。
请注意,上面的代码返回的是最大重量,而不是最大价值。如果需要返回最大价值,我们需要对每个物品的价值进行记录,并在最后遍历 `bitset` 时,找到对应的最大价值。这通常需要额外的数据结构来存储每个重量对应的价值。
<<提问分享>>
画一个红酒广告画一个金狮雕像
画一个法治社的宣传海报
从前,在一个遥远的国度里,有一条神奇的龙,它名叫青
一个姐姐,一个妹妹,一个弟弟,爸爸妈妈,和谐的在吃饭
画一个百年巨龟
街舞社海报 有中文的“街舞社”在中间 图中的人物是青春阳光的学生
阴雨连绵,富有山水诗意,烟雾缭绕的画
画一个小女孩晚上穿着白色连衣裙在大海边站在沙滩边踩水身边群星闪耀,要正面照
一只橘猫趴在开满花朵树上睡觉
一只坐在水池旁 桃花树下 看着水池中的鱼的猫
以消防安全为主题,创作一张插画,主体为消防车、起火的建筑颜色为红色、橙色、高对比度
青春阳光的街舞社海报
主体:一位手持宝剑头戴帷帽身着白衣的女侠客 环境:与世隔绝的深山老林 2D插画
省实民乐团画报
以消防安全为主题,创作一张插画
有山,有河流,还有一片竹林
阳光明媚的天气,阳光偏黄柔和,一只品种为金毛的小狗,在有花有草的森林里玩皮球
油画郁金香花海落日真实照片
街舞社海报 青春阳光 有“街舞社”在中间偏上
云山文学社海报 诗意 故事 文章
一个古老的佛像,以山为背景,佛像
谷歌小恐龙
真实照片油画玫瑰花
主题:街舞社海报
画一个戏剧社海报
绿色,古代,男子
青年女运动员在羽毛球馆打羽毛球,人物居中
画一个炸鸡在白色瓷碟,背景是大山中
主体:一座古老的寺庙 环境:山脉之中,旁边有瀑布流淌 行为:游客在参观,拍照 色彩:绿色和金色为主 构图:寺庙居中,瀑布和山脉作为背景 风格:写实
真实照片, 朦胧远山,柳树,雨水,2D插画
干白葡萄酒在自然大气的暗绿色背景里的广告
卖油翁背后的道理
http://chatgpt.jupyter.vip/pic/1173.jpg
画图:龙飞凤舞
讲一个关于龙的故事
画图:白云山
画图:水鱼
画图:鱼香茄子
mysql备份数据库如何指定端口
用python程序揭示位图和矢量图的区别
Ubuntu系统使用iptables开放指定端口
简单介绍PPT中插入超链接
简单介绍PPT中幻灯片的背景设置
简单介绍PPT中自定义动画
简单介绍幻灯片切换效果
用python获取PPT幻灯片数量,以及第二张幻灯片的标题及字体
Jupyter中用python程序显示图像文件
Windows平台host解析域名
用python开发一个考勤系统