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 小米 华为 单反 装机 图拉丁
 
   -> 游戏开发 -> 简单的数据压缩 -> 正文阅读

[游戏开发]简单的数据压缩

简单的数据压缩

压缩实际上就是一种节省空间的行为,比如一个字符占8位,当我们需要用一串字符来记录某种信息时,所占大小就是字符数x8.比如现在需要记录某一串遗传信息核苷酸ATCG。

eg:ATCGATTCTG

则需要10x8 = 80位。

因为以上的字符比较特殊,它是只有4个符号组成,那么我们约定:用2位存储来指代上面的其中一个符号,则就能达到节省空间的目的。

eg:A:00 T:01 C:10 G:11

那么上述字符串就能压缩成:00011011000101100111,只需要10x2=20位就能完成对该信息的存储。

这就是压缩原理。

需要解压缩的时候,再按每两位取出其中的值,通过枚举就能够解析原来存储的信息。当然这些压缩和解压缩需要事先进行设计的。

import Foundation

struct CompressedGene {
    let lenght:Int
    private let bitVector : CFMutableBitVector
    
    init(string:String) {
        lenght = string.count
        bitVector = CFBitVectorCreateMutable(kCFAllocatorDefault, lenght*2)
        CFBitVectorSetCount(bitVector, lenght*2)
        compress(gene: string)
    }
    
    private func compress(gene:String){
        for (index,item) in gene.uppercased().enumerated() {
            let start = index*2
            switch item {
            case "A":
                //其中bitVector是压缩后的对象,start是往对象添加数据的位置,最后一位是添加的内容
                //此处添加的是00
                CFBitVectorSetBitAtIndex(bitVector, start, 0)
                CFBitVectorSetBitAtIndex(bitVector, start+1, 0)
            case "T"://01
                CFBitVectorSetBitAtIndex(bitVector, start, 0)
                CFBitVectorSetBitAtIndex(bitVector, start+1, 1)
            case "C"://10
                CFBitVectorSetBitAtIndex(bitVector, start, 1)
                CFBitVectorSetBitAtIndex(bitVector, start+1, 0)
            case "G"://11
                CFBitVectorSetBitAtIndex(bitVector, start, 1)
                CFBitVectorSetBitAtIndex(bitVector, start+1, 1)
            default:
                print("混入了奇奇怪怪的东西,在第\(index)位")
            }
        }
    }
}

print("\(CompressedGene(string: "ATCGATTCTG"))")

运行结果:
在这里插入图片描述

解压缩

private func decompress()->String{
        var gene:String = ""
        for index in 0 ..< lenght {
            let start = index*2
            let firstBit = CFBitVectorGetBitAtIndex(bitVector, start)
            let nextBit = CFBitVectorGetBitAtIndex(bitVector, start+1)
            
            switch (firstBit,nextBit) {
            case (0,0):
                gene += "A"
            case (0,1):
                gene += "T"
            case (1,0):
                gene += "C"
            case (1,1):
                gene += "G"
            default:
                break
            }
        }
        return gene
    }
  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章      下一篇文章      查看所有文章
加:2022-05-06 11:17:25  更:2022-05-06 11:18:26 
 
开发: 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/17 0:51:53-

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