C++ 连续数值转区间计算

19 篇文章 0 订阅
7 篇文章 0 订阅
代码 

class UnicodeRange {
public:
    uint32_t start = 0;
    uint32_t end = 0;
};
using UnicodeRanges = std::vector<UnicodeRange>;

UnicodeRanges getRanges(const std::set<uint32_t>& unicodes)
{
    if (unicodes.empty())
        return {};
    UnicodeRanges ranges;
    if (*unicodes.begin() + unicodes.size() == *unicodes.rbegin()) { // 全部连续
        ranges.emplace_back(
            UnicodeRange { *unicodes.begin(), (uint32_t)(*unicodes.begin() + unicodes.size()) });
        return ranges;
    }

    UnicodeRange curRange;
    curRange.start = *unicodes.begin();
    curRange.end = *unicodes.begin();
    for (const auto& code : unicodes) {
        if (code == curRange.end) {
            curRange.end = code + 1;
        } else {
            ranges.emplace_back(curRange);
            curRange.start = code;
            curRange.end = code + 1;
        }
    }
    if (ranges.empty() || ranges.back().start != curRange.start)
        ranges.emplace_back(curRange); // 尾部连续
    return ranges;
}
测试
    std::set<uint32_t> ranges { 1, 2, 3, 4, 9, 22, 23, 24, 90, 91, 100 };
    auto blockRanges = getRanges(ranges);
    for (const auto& block : blockRanges) {
        LOG_INFO_STREAM << "block: " << block.start << " - " << block.end << std::endl;
    }
输出
block: 1 - 5
block: 9 - 10
block: 22 - 25
block: 90 - 92
block: 100 - 101

创作不易,小小的支持一下吧!

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码力码力我爱你

创作不易,小小的支持一下吧!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值