面向云技术架构 - 痴者工良

  • 首页
  • 工良写的电子书
    • kubernetes 教程
    • 从 C# 入门 Kafka
    • 多线程和异步
    • 动态编程-反射、特性、AOP
    • 表达式树
  • 本站文章导航
  • 隐私政策
愿有人陪你颠沛流离
遇到能让你付出的事物或者人,都是一种运气。
能遇到,就该珍惜。或许你们最终没能在一起,但你会切实地感受到力量。
正因为这样,那段相遇才变得有价值,才没有辜负这世间的每一段相遇。
  1. 首页
  2. .NET
  3. 正文

C# 简单字符串压缩算法

2023年2月13日 202点热度 1人点赞 0条评论
内容纲要
void Main()
{
    string str = "A-A01A05-A01-01-02";
    byte[] data = new byte[16];
    var span = data.AsSpan();

    ulong l = 0;
    int index = 1;
    int count = 0;
    for (int i = 0; i < str.Length; i++)
    {
        var value = HashFind.GetValue(str[i]);
        if (index <= 10)
        {
            l <<= 6;
            l = l | value;
            index++;
        }
        if (index == 11 || i + 1 >= str.Length)
        {
            BinaryPrimitives.TryWriteUInt64LittleEndian(span[count..(count + 8)], l);
            l = 0;
            index = 1;
            count += 8;
        }
    }
    Console.WriteLine(BinaryPrimitives.ReadInt64LittleEndian(data[0..8]));
    Console.WriteLine(BinaryPrimitives.ReadInt64LittleEndian(data[8..16]));
}

public static class HashFind
{
    private const byte A = (byte)'A';      // 65
    private const byte Z = (byte)'Z';      // 90
    private const byte Zero = (byte)'0';   // 48
    private const byte Nine = (byte)'9';   // 57

    //private static readonly char[] Dic = new char[] {'0','1','2','3','4','5','6','7','8','9',
    //                           'A', 'B', 'C', 'D', 'D', 'E', 'E', 'E',
    //                           'E', 'F', 'G', 'H', 'H', 'I', 'J', 'K',
    //                           'L', 'M', 'N', 'O', 'O', 'O', 'O', 'P',
    //                           'Q', 'R', 'R', 'T', 'U', 'U', 'V', 'W',
    //                           'X', 'Y', 'Z','-'};

    public static byte GetValue(char ch)
    {
        if (ch.Equals('-')) return (byte)36;
        var upper = char.ToUpper(ch);
        var value = (byte)upper;
        // 0-9
        if (Zero <= value && value <= Nine)
        {
            return (byte)(value - Zero);
        }
        // 10-35
        else if (A <= value && value <= Z)
        {
            return (byte)(value - A + (byte)10);
        }
        throw new InvalidDataException("字符值不在范围内");
    }
}
本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可
标签: c 压缩算法 字符串 简单
最后更新:2023年2月13日

痴者工良

高级程序员劝退师

点赞
< 上一篇
下一篇 >

文章评论

razz evil exclaim smile redface biggrin eek confused idea lol mad twisted rolleyes wink cool arrow neutral cry mrgreen drooling persevering
取消回复

COPYRIGHT © 2022 whuanle.cn. ALL RIGHTS RESERVED.

Theme Kratos Made By Seaton Jiang

粤ICP备18051778号

粤公网安备 44030902003257号