程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> C++入門知識 >> c++ 實現atoi()函數

c++ 實現atoi()函數

編輯:C++入門知識

c++ 實現atoi()函數


1. 問題描述

  實現c++函數庫中atoi()函數,要考慮到各種特殊情況:
  

空字符串。 +和-號。 字符串前中後n個空格。 溢出。 非數字字符。

2. 解決方案

  轉換過程並不復雜,復雜的是要考慮到眾多特殊情況。

int myAtoi(string str) {
        if(str.length() == 0) return 0; //空串

        bool isNeg = false;
        long re = 0;
        int i=0,cnt;
        for(;i= '0' && str[i] <= '9')
            re = str[i] - '0',cnt=1;  //記錄數字的位數
        else return 0;

        i++;   
        for(; i < str.length(); i++)
        {
            if (cnt > 10) break; //大於整數所表示的最大位數,跳出循環
            if(str[i] < '0' || str[i] > '9')  break;  
            re = re*10 + (str[i] - '0'),cnt++;
        }

        //溢出判斷
        if(re > INT_MAX && !isNeg) return INT_MAX; 
        else if(isNeg &&re*(-1) < INT_MIN) return INT_MIN;
        return isNeg?re*(-1):re;
    }

 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved