• <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>
            隨筆 - 96  文章 - 255  trackbacks - 0
            <2008年3月>
            2425262728291
            2345678
            9101112131415
            16171819202122
            23242526272829
            303112345

            E-mail:zbln426@163.com QQ:85132383 長期尋找對戰略游戲感興趣的合作伙伴。

            常用鏈接

            留言簿(21)

            隨筆分類

            隨筆檔案

            SDL相關網站

            我的個人網頁

            我的小游戲

            資源下載

            搜索

            •  

            積分與排名

            • 積分 - 492247
            • 排名 - 38

            最新評論

            閱讀排行榜

            評論排行榜

            作者:龍飛

                    我下面考慮的問題,是用TextSurface反饋鼠標事件的信息。我想到的第一個例子,很自然就是反饋鼠標所在坐標的位置。這里涉及到一個基礎的問題,即鼠標位置顯然不是用字符串表示的。SDL給我們的反饋信息是int,我們需要用TextSurface將int構建成可以被blit到ScreenSurface上的面,需要做的第一件事情,是將int轉換為string。
                    我的思路是這樣的:首先找到int的數位數;然后依次從高位讀取數字,之后將這個位去掉(通常減掉是最簡單的);依次記錄這些數字,轉換成string,然后將這些數字“加”(字符串的合并)起來。
            頭文件如下:
            //UVi Soft (2008)
            //Long Fei (lf426), E-mail: zbln426@163.com

            //FileName: int_to_string.h

            #ifndef INT_TO_STRING_H_
            #define INT_TO_STRING_H_

            #include 
            <iostream>
            #include 
            <string>
            #include 
            <vector>

            int int_power(int baseint exp);
            std::
            string int_to_string(int num);

            #endif
                    其中,int_to_string()是我們需要構建的函數,int_power()是求一個數的整數冪的函數。這么簡單的算法,我們就自己寫吧。至于用到vector,按照我的思路,我們需要的數據結構顯然應該是“隊列”(先進先出)。不過真得感謝STL,用vector顯然不是最優化的,但是肯定是最“通俗”的,因為即使是作為非專業的隊列(或者棧),vector也已經為我們提供了必要的方法,比如推入(push_back)。
                    下面我就把程序說明夾在程序中間了。原因是本人英語太菜,簡單描述還能忍,描述算法就有點不能忍了-_-!!!。另外,盡管我英語這水平,我還是希望程序里面別用中文注釋的好。這種事情,您見過一次亂碼,就總是得惡心一輩子。
            //UVi Soft (2008)
            //Long Fei (lf426), E-mail: zbln426@163.com

            #include 
            "int_to_string.h"

            int int_power(int baseint exp)
            {
                
            int result = 1;
                
            for (int i = exp; i > 0; i-- )
                    result
            *=base;
                
            return result;
            }
            這是個很簡單的求冪的算法。其實我們在程序中,只需要用到求10的n次冪,所以,實際上我們還可以寫得更加有針對一點。
            std::string int_to_string(int num)
            {
                
            bool negative = false;
                
            if ( num < 0 ){
                    negative 
            = true;
                    num 
            = -num;
                }
            這開始寫轉換函數了。首先我們判定int是否為負。如果是,我們把它變成其相反數,然后與正數一樣轉換,最后在前面加上“-”就OK了。
                int bitNum = 1;
                
            for ( int i = num; i > 9; i/=10 )
                    bitNum
            ++;
            bitNum是這個int的數位數。比如3就是1位,1024就是4位。
                std::vector<int> eachNum;
                
            for ( int i = bitNum, temp = num; i > 0; i-- ){
                    
            int highBit = int(temp/int_power(10, (i-1)));
                    eachNum.push_back(highBit);
                    temp
            -=(highBit*int_power(10, (i-1)));
                }
            我們通過vector數組紀錄每個數位上的數字,從高位到低位。需要說明的是,n位的數字是10的n-1次方冪。比如1024是4位,而1000是10的3次方冪。所以,我們這里用的是i-1而非i。
                std::string str;
                
            if ( negative == true )
                    str 
            = "-";
                
            for ( std::vector<int>::iterator pTemp = eachNum.begin(); pTemp != eachNum.end(); pTemp++ ){
                    
            switch ( *pTemp ){
                        
            case 0:
                            str
            +="0";
                            
            break;
                        
            case 1:
                            str
            +="1";
                            
            break;
                        
            case 2:
                            str
            +="2";
                            
            break;
                        
            case 3:
                            str
            +="3";
                            
            break;
                        
            case 4:
                            str
            +="4";
                            
            break;
                        
            case 5:
                            str
            +="5";
                            
            break;
                        
            case 6:
                            str
            +="6";
                            
            break;
                        
            case 7:
                            str
            +="7";
                            
            break;
                        
            case 8:
                            str
            +="8";
                            
            break;
                        
            case 9:
                            str
            +="9";
                            
            break;
                        
            default:
                            
            break;
                    }
                }
                
            return str;
            }
            最后,我們用了STL的方法將每個數字轉換成std::string的字符串,然后將這些字符串合并起來,作為函數的返回值。
                    我們在下一節中將用TextSurface演示這個函數的作用,以及實現我們在本節前面所提出的問題。
            posted on 2008-03-26 20:48 lf426 閱讀(4278) 評論(8)  編輯 收藏 引用 所屬分類: SDL入門教程 、語言基礎、數據結構與算法

            FeedBack:
            # re: SDL入門教程(九):4、int轉換為std::string 2008-07-20 14:50 zhou
            #include <sstream>
            #include <string>
            using namespace std;


            //具體函數有些忘了,不過使用sstream轉換數字肯定
            //比自己寫好一些。因為可以寫模板轉換float數字。
            string int_to_string(int num)
            {
            sstream<string > ss;
            ss << num;

            return ss.ToString();
            }

            //這是模板函數,可能語法上有不正確的地方,你可以查查書籍就可以了,
            //重要的不是語法,而是思想。
            template<class T>
            string num_to_string(T num)
            {
            sstream<string > ss;
            ss << num;

            return ss.ToString();

            }  回復  更多評論
              
            # re: SDL入門教程(九):4、int轉換為std::string 2008-07-20 15:00 zhou
            我是zhou,歡迎到我的博客來。  回復  更多評論
              
            # re: SDL入門教程(九):4、int轉換為std::string[未登錄] 2008-07-21 13:29 lf426
            感謝您的指教,我對C++標準庫的了解還是不多啊,其實我一直就覺得這樣的功能標準庫應該提供的,之前一直沒有google到。  回復  更多評論
              
            # re: SDL入門教程(九):4、int轉換為std::string[未登錄] 2008-09-27 10:59 伊凡
            具體實現是:
            std::string int_to_string(int num)
            {
            std::ostringstream ss;
            ss << num;
            return ss.str();
            }
              回復  更多評論
              
            # re: SDL入門教程(九):4、int轉換為std::string[未登錄] 2008-09-27 11:20 lf426
            謝謝。呵呵,這種看起來小的知識點,很多書上都沒提到,但是其實很實用。  回復  更多評論
              
            # re: SDL入門教程(九):4、int轉換為std::string[未登錄] 2009-01-01 20:10 Felicia
            這么實現也很簡單:)

            string int2string(const int &a) {
            char buf[10];
            sprintf(buf, "%d", a);
            return string(buf);
            }
              回復  更多評論
              
            # re: SDL入門教程(九):4、int轉換為std::string 2010-08-25 09:22 DN
            @伊凡
            嗯 用流更方便  回復  更多評論
              
            # re: SDL入門教程(九):4、int轉換為std::string 2015-07-03 16:13 Haven
            sprintf就是呀  回復  更多評論
              
            亚洲国产一成久久精品国产成人综合 | 一本久久综合亚洲鲁鲁五月天| 人人狠狠综合久久88成人| 国产精品久久久久一区二区三区| 久久人人爽人人爽人人AV东京热| 精品熟女少妇AV免费久久| 亚州日韩精品专区久久久| 无码8090精品久久一区| 亚洲另类欧美综合久久图片区| 亚洲午夜久久久| 国产69精品久久久久观看软件| 久久99国产精品久久99小说| 久久99九九国产免费看小说| 亚洲精品无码专区久久久| 伊人久久无码中文字幕| 国内精品久久久人妻中文字幕| 国产精品国色综合久久| 久久国产精品久久| 国产精品九九久久精品女同亚洲欧美日韩综合区| 久久中文骚妇内射| 国产激情久久久久影院小草| 久久精品国产亚洲5555| 亚洲天堂久久久| 99久久中文字幕| 久久无码人妻精品一区二区三区 | 久久成人18免费网站| 久久精品无码av| 久久国产免费直播| 久久久老熟女一区二区三区| 久久国产精品久久| 中文字幕无码久久精品青草 | 久久青青草原精品国产不卡| 久久天天躁夜夜躁狠狠躁2022| 99精品久久精品一区二区| 精品国产一区二区三区久久蜜臀| 少妇久久久久久被弄到高潮 | 2021少妇久久久久久久久久| 少妇久久久久久被弄到高潮| 国产成年无码久久久久毛片| 久久国产视屏| 国产一区二区精品久久|