• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            C小加

            厚德 博學(xué) 求真 至善 The bright moon and breeze
            posts - 145, comments - 195, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理
            //函數(shù)名:myatof
            //功能:把字符串轉(zhuǎn)化成double浮點(diǎn)型
            //名字來源:my array to floating point numbers  
            //函數(shù)說明:接收一個(gè)字符串判斷第一個(gè)字符的符號(hào),沒有符號(hào)默認(rèn)為正值,然后對(duì)剩余字符串進(jìn)行轉(zhuǎn)換,//遇到\0結(jié)束,最后返回一個(gè)double

            double myatof(const char* sptr)
            {
                double temp=10;
                bool ispnum=true;
                double ans=0;
                if(*sptr=='-')//判斷是否是負(fù)數(shù)
                {
                    ispnum=false;
                    sptr++;
                }
                else if(*sptr=='+')//判斷是否為正數(shù)
                {
                    sptr++;
                }

                while(*sptr!='\0')//尋找小數(shù)點(diǎn)之前的數(shù)
                {
                    if(*sptr=='.'){ sptr++;break;}
                    ans=ans*10+(*sptr-'0');
                    sptr++;
                }
                while(*sptr!='\0')//尋找小數(shù)點(diǎn)之后的數(shù)
                {
                    ans=ans+(*sptr-'0')/temp;
                    temp*=10;
                    sptr++;
                }
                if(ispnum) return ans;
                else return ans*(-1);
            }

            //函數(shù)名:myatoi
            //功能:把字符串轉(zhuǎn)化成int整型
            //名字來源:my array to integer  
            //函數(shù)說明:接收一個(gè)字符串判斷第一個(gè)字符的符號(hào),沒有符號(hào)默認(rèn)為正值,然后對(duì)剩余字符串進(jìn)行轉(zhuǎn)換,//遇到\0結(jié)束,最后返回一個(gè)int

            int myatoi(const char* sptr)
            {

                bool ispnum=true;
                int ans=0;
                if(*sptr=='-')//判斷是否是負(fù)數(shù)
                {
                    ispnum=false;
                    sptr++;
                }
                else if(*sptr=='+')//判斷是否為正數(shù)
                {
                    sptr++;
                }

                while(*sptr!='\0')//類型轉(zhuǎn)化
                {
                    ans=ans*10+(*sptr-'0');
                    sptr++;
                }

                if(ispnum) return ans;
                else return ans*(-1);
            }

            Feedback

            # re: 自己實(shí)現(xiàn)的atof()和atoi()代碼[未登錄]  回復(fù)  更多評(píng)論   

            2012-02-24 19:53 by ithaca
            沒有處理前置的空白,這個(gè)功能,標(biāo)準(zhǔn)的atoi都是要有的。

            # re: 自己實(shí)現(xiàn)的atof()和atoi()代碼  回復(fù)  更多評(píng)論   

            2012-02-25 21:24 by ko
            正數(shù)不一定非要用 + 占位吧

            # re: 自己實(shí)現(xiàn)的atof()和atoi()代碼  回復(fù)  更多評(píng)論   

            2012-02-27 09:10 by C小加
            遇到+了怎么辦@ko

            # re: 自己實(shí)現(xiàn)的atof()和atoi()代碼  回復(fù)  更多評(píng)論   

            2013-11-09 11:25 by danielyin
            atoi沒有考慮溢出的問題。

            # re: 自己實(shí)現(xiàn)的atof()和atoi()代碼  回復(fù)  更多評(píng)論   

            2014-09-05 22:27 by memristor
            定義函數(shù) double atof(const char *nptr);
            函數(shù)說明 atof()會(huì)掃描參數(shù)nptr字符串,跳過前面的空格字符,直到遇上數(shù)
            字或正負(fù)符號(hào)才開始做轉(zhuǎn)換,而再遇到非數(shù)字或字符串結(jié)束時(shí)
            ('\0')才結(jié)束轉(zhuǎn)換,并將結(jié)果返回。參數(shù)nptr字符串可包含正負(fù)
            號(hào)、小數(shù)點(diǎn)或E(e)來表示指數(shù)部分,如123.456或123e-2。
            返回值 返回轉(zhuǎn)換后的浮點(diǎn)型數(shù)。
            #include <stdio.h>
            #include <ctype.h>
            #include <math.h>
            #include <stdlib.h>
            #include <assert.h>


            double myatof(const char*s)
            {
            assert(s!=NULL);
            double val,val2,power;
            int sign,sign2,i;
            //去掉字符串中的空格
            for(i=0;isspace(s[i]);++i)
            ;
            //判斷正負(fù)數(shù) ,并將i指向下一個(gè)位置
            sign = (s[i] == '-') ? -1:1;
            if(s[i] == '+' || s[i] == '-')
            i++;
            //取浮點(diǎn)數(shù)的整數(shù)部分
            for(val=0.0;isdigit(s[i]) && s[i] !=0;++i)
            val = 10*val+s[i]-'0';
            //取小數(shù)點(diǎn)
            if(s[i] == '.')
            i++; //后一個(gè)位置
            //取小數(shù)點(diǎn)后面數(shù)
            for(power=1.0;isdigit(s[i]) && s[i] !=0;++i)
            {
            val = 10*val+s[i]-'0';
            power*=10; //float 放大的倍數(shù)
            }
            val=sign*val/power;

            //如果有e的話處理e后面的數(shù)字
            if(s[i]=='e' || s[i]== 'E'){
            i++;
            sign2 = (s[i] == '-')?-1:1;
            if(s[i] == '+' || s[i] == '-')
            i++;
            for(val2=0.0;isdigit(s[i]) && s[i] !=0;++i){
            val2 = 10*val2+s[i]-'0';
            }
            if(sign2 == -1)
            return val/pow(10,val2);
            else
            return val*pow(10,val2);
            }
            return val;
            }
            国产成人精品久久| 青青草国产成人久久91网| 国产免费久久久久久无码| 国产午夜精品久久久久免费视| 日韩人妻无码精品久久免费一| 日韩精品久久久久久| 久久天天躁狠狠躁夜夜不卡| 99久久免费国产精品| 久久国产影院| 伊人久久大香线蕉综合热线| 亚洲人成网站999久久久综合 | 久久久无码精品午夜| 97久久久久人妻精品专区 | 久久精品国产WWW456C0M| 色综合久久综合中文综合网| 久久精品人人做人人爽电影蜜月| 精品久久久久香蕉网| MM131亚洲国产美女久久| 久久婷婷久久一区二区三区| 久久99亚洲综合精品首页| 色欲综合久久躁天天躁| 伊人久久精品无码二区麻豆| 69久久精品无码一区二区| 精品久久国产一区二区三区香蕉 | 性做久久久久久久久久久| 久久中文字幕无码专区| 久久精品国产99国产精品导航| 久久久久久无码Av成人影院| 伊人色综合久久| 久久久久人妻一区二区三区| 久久这里只有精品久久| 久久夜色撩人精品国产| 亚洲国产精品一区二区久久hs| 精品无码久久久久久久久久| 久久国产欧美日韩精品免费| 国产精品久久影院| 欧美日韩精品久久免费| 亚洲国产精品久久| 久久亚洲精品中文字幕| 日本精品久久久久影院日本| 999久久久免费精品国产|