IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> leetcode 设计位集 -> 正文阅读

[数据结构与算法]leetcode 设计位集

位集 Bitset?是一种能以紧凑形式存储位的数据结构。

请你实现?Bitset?类。

  • Bitset(int size)?用?size?个位初始化 Bitset ,所有位都是?0?。
  • void fix(int idx)?将下标为?idx?的位上的值更新为?1?。如果值已经是?1?,则不会发生任何改变。
  • void unfix(int idx)?将下标为?idx?的位上的值更新为?0?。如果值已经是?0?,则不会发生任何改变。
  • void flip()?翻转 Bitset 中每一位上的值。换句话说,所有值为?0?的位将会变成?1?,反之亦然。
  • boolean all()?检查?Bitset 中?每一位?的值是否都是?1?。如果满足此条件,返回?true?;否则,返回?false?。
  • boolean one()?检查?Bitset 中 是否?至少一位?的值是?1?。如果满足此条件,返回?true?;否则,返回?false?。
  • int count()?返回 Bitset 中值为 1 的位的?总数?。
  • String toString()?返回 Bitset 的当前组成情况。注意,在结果字符串中,第?i?个下标处的字符应该与 Bitset 中的第?i?位一致。

示例:

输入
["Bitset", "fix", "fix", "flip", "all", "unfix", "flip", "one", "unfix", "count", "toString"]
[[5], [3], [1], [], [], [0], [], [], [0], [], []]
输出
[null, null, null, null, false, null, null, true, null, 2, "01010"]

解释
Bitset bs = new Bitset(5); // bitset = "00000".
bs.fix(3);     // 将 idx = 3 处的值更新为 1 ,此时 bitset = "00010" 。
bs.fix(1);     // 将 idx = 1 处的值更新为 1 ,此时 bitset = "01010" 。
bs.flip();     // 翻转每一位上的值,此时 bitset = "10101" 。
bs.all();      // 返回 False ,bitset 中的值不全为 1 。
bs.unfix(0);   // 将 idx = 0 处的值更新为 0 ,此时 bitset = "00101" 。
bs.flip();     // 翻转每一位上的值,此时 bitset = "11010" 。
bs.one();      // 返回 True ,至少存在一位的值为 1 。
bs.unfix(0);   // 将 idx = 0 处的值更新为 0 ,此时 bitset = "01010" 。
bs.count();    // 返回 2 ,当前有 2 位的值为 1 。
bs.toString(); // 返回 "01010" ,即 bitset 的当前组成情况。

提示:

  • 1 <= size <= 105
  • 0 <= idx <= size - 1
  • 至多调用?fixunfixflipallonecount?和?toString?方法?总共?105?次
  • 至少调用?allonecount?或?toString?方法一次
  • 至多调用?toString?方法?5?次

C++

class Bitset {
public:
    Bitset(int size) {
        string tmp(size,'0');
        s=tmp;
        num=0;
        sum=size;
        isFlip=false;
    }
    
    void fix(int idx) {
        if(isFlip==false) {
            if(s[idx]=='0') {
                s[idx]='1';
                num++;
            }            
        } else {
            if(s[idx]=='1') {
                s[idx]='0';
                num++;
            }
        }
    }
    
    void unfix(int idx) {
        if(isFlip==false) {
            if(s[idx]=='1') {
                s[idx]='0';
                num--;
            }            
        } else {
            if(s[idx]=='0') {
                s[idx]='1';
                num--;
            }
        }
    }
    
    void flip() {
        if(isFlip==false) {
            isFlip=true;
        } else {
            isFlip=false;
        }
        num=sum-num;
    }
    
    bool all() {
        return num==sum;
    }
    
    bool one() {
        return num>0;
    }
    
    int count() {
        return num;
    }
    
    string toString() {
        if(isFlip==false) {
            return s;
        } else {
            string ans;
            for(int i=0;i<s.size();i++) {
                if(s[i]=='0') {
                    ans+='1';
                } else {
                    ans+='0';
                }
            }
            return ans;
        }
    }
private:
    string s;
    int num;
    int sum;
    bool isFlip;
};

/**
 * Your Bitset object will be instantiated and called as such:
 * Bitset* obj = new Bitset(size);
 * obj->fix(idx);
 * obj->unfix(idx);
 * obj->flip();
 * bool param_4 = obj->all();
 * bool param_5 = obj->one();
 * int param_6 = obj->count();
 * string param_7 = obj->toString();
 */

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-02-07 13:58:02  更:2022-02-07 13:58:43 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 10:54:49-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码