C++字符串数字的比较

假设:

有这么一个字符串集合,"1","2","3",........."10000000", "40","20".

 

要求进行排序。

 

基本想法: 把字符串转化为数字,进行对比。

 

但是有一个问题:也许这个字符串的长度超过了 普通整数的范围了,怎么办? 有人说用 long long ,可以,但不优雅,而且无法对更加大的数字进行排序。

 

解决方法: 使用大数的思想。代码如下;

 

#include <iostream>
#include <functional>
#include <map>
#include <string>
#include <vector>
#include <iterator>
#include <algorithm>
#include <utility>
#include <cassert>
using namespace std;


struct string_Intnumber_checker{
    bool  operator()(const string& str) const{
        if(!str.empty())
          {
              if(string::npos == str.find_first_not_of("0123456789"))
              {
                   return true;
              }
          }
      
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值