• <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>
            我要啦免费统计
            幾百年沒有寫小程序玩。

            //1 2 3 5 6 8 9   ->  1-3,5-6,8,9


              1#include "generator1.h"
              2
              3typedef std::vector<std::wstring> WSTRVECTOR;
              4typedef std::vector<int> INTVECTOR;
              5
              6struct range
              7{
              8    int start;
              9    int end;
             10}
            ;
             11typedef std::vector<range> RGVECTOR;
             12
             13void CovertToRangeVector( INTVECTOR &nINTVECTOR, RGVECTOR &rgVector ) 
             14{
             15    INTVECTOR::size_type pos = 0;
             16    int nPre = -1;
             17    int nIndex = -1;
             18    while (pos < nINTVECTOR.size())
             19    {
             20        if (0 == pos)
             21        {
             22            nPre = nINTVECTOR[pos];
             23            range rgTemp;
             24            rgTemp.start = rgTemp.end = nPre;
             25            rgVector.push_back(rgTemp);
             26            ++pos;
             27            ++nIndex;
             28            continue;
             29        }

             30
             31        if (1 == nINTVECTOR[pos] - nPre)
             32        {
             33            rgVector[nIndex].end = nINTVECTOR[pos];
             34            nPre = nINTVECTOR[pos];
             35            ++pos;
             36            continue;
             37        }

             38        else
             39        {
             40            range rgTemp;
             41            rgTemp.start = rgTemp.end = nINTVECTOR[pos];
             42            rgVector.push_back(rgTemp);
             43            nPre = nINTVECTOR[pos];
             44            ++pos;
             45            ++nIndex;
             46            continue;
             47        }

             48    }

             49}

             50
             51void ConvertToWstringVector( RGVECTOR &rgVector, WSTRVECTOR &wstrvtUserStringAns ) 
             52{
             53    for (RGVECTOR::size_type pos = 0; pos < rgVector.size(); ++pos)
             54    {
             55        //s - e, s - e, e
             56        std::wstring wstrRange;
             57        std::wstring wstrStart;
             58        std::wstring wstrEnd;
             59
             60        if (rgVector[pos].start != rgVector[pos].end)
             61        {
             62            wstring wstrTemp;
             63            wchar_t Buffer[256= {0};
             64            int nStart = rgVector[pos].start;
             65            _ltow_s(rgVector[pos].start, Buffer, 10);
             66            //swprintf(Buffer, L"%d", L"DSDASDA");
             67            wstrTemp.assign(Buffer);
             68            wstrTemp.append(L"-");
             69            _ltow_s(rgVector[pos].end, Buffer, 10);
             70            //swprintf(Buffer, L"%d", L"DSDASDA");
             71            wstrTemp.append(Buffer);
             72
             73            wstrRange.append(wstrTemp);
             74        }

             75        else
             76        {
             77            WCHAR Buffer[256= {0};
             78            _ltow_s(rgVector[pos].start, Buffer, 10);
             79            /*wsprintf(Buffer, L"%d", rgVector[pos].start);*/
             80            wstring wstrTemp;
             81            wstrTemp.assign(Buffer);
             82
             83            wstrRange.append(wstrTemp);
             84        }

             85
             86        if (pos + 1 < rgVector.size())
             87        {
             88            wstrRange.append(L",");
             89        }

             90        wstrvtUserStringAns.push_back(wstrRange);
             91    }

             92}

             93HRESULT SimpleGeneratorToUserString(INTVECTOR &nINTVECTOR, WSTRVECTOR &wstrvtUserString)
             94{
             95    //1 2 3 5 6 8 9   ->  1-3,5-6,8,9
             96    //ASSERT(!nINTVECTOR.empty());
             97    if (nINTVECTOR.empty())
             98    {
             99        return E_FAIL;
            100    }

            101    RGVECTOR rgVector;
            102    //
            103    CovertToRangeVector(nINTVECTOR, rgVector);
            104
            105    //WSTRVECTOR wstrvtUserStringAns;
            106    //to string
            107    ConvertToWstringVector(rgVector, wstrvtUserString);
            108
            109    return S_OK;
            110}

            111
            112//
            113//HRESULT SimpleGeneratorToUserString(INTVECTOR &nINTVECTOR, WSTRVECTOR &wstrvtUserString)
            114int main()
            115{
            116    INTVECTOR nINTVECTOR;
            117    WSTRVECTOR wstrvtUserString;
            118    //int a[10] = {1,2,3,5,8,9,10,100};
            119    //int a[10] = {1};
            120    int a[2= {1,100};
            121    for (int pos = 0; pos < 2++pos)
            122    {
            123        nINTVECTOR.push_back(a[pos]);
            124    }

            125    SimpleGeneratorToUserString(nINTVECTOR, wstrvtUserString);
            126    for (WSTRVECTOR::size_type pos = 0; pos < wstrvtUserString.size(); ++pos)
            127    {
            128        wstring wstrtemp = wstrvtUserString[pos];
            129        wcout<<wstrtemp;
            130        //printf("%s",wstrvtUserString[pos]);
            131    }

            132    system("pause");
            133    return 0;
            134}
            posted on 2011-02-17 14:42 閱讀(2072) 評論(0)  編輯 收藏 引用 所屬分類: 測試訓練
            久久久久亚洲AV无码专区首JN | 国产成人精品久久免费动漫| 色青青草原桃花久久综合| 久久人人添人人爽添人人片牛牛| 国产精品久久永久免费| 久久精品国产只有精品2020| 国产ww久久久久久久久久| 精品久久久久成人码免费动漫| 久久久久久无码Av成人影院| 国产成人久久AV免费| 深夜久久AAAAA级毛片免费看| 国产精品久久99| 要久久爱在线免费观看| 亚洲国产精品久久久久婷婷老年| 少妇熟女久久综合网色欲| 久久久91精品国产一区二区三区| 久久精品无码一区二区WWW| 久久精品国产亚洲AV电影 | 99久久精品国产高清一区二区| 亚洲伊人久久综合中文成人网| 99久久精品免费看国产免费| 伊人情人综合成人久久网小说| 久久国产高清一区二区三区| 久久99国产综合精品免费| 尹人香蕉久久99天天拍| 国产精品久久久久乳精品爆| 国产精品久久久久久影院| 久久精品成人欧美大片| 亚洲va久久久久| 久久久噜噜噜久久| 久久精品成人欧美大片| 久久国产精品-久久精品| 久久Av无码精品人妻系列| 久久精品国产亚洲AV影院| 久久精品中文字幕大胸| 亚洲а∨天堂久久精品| 亚洲伊人久久成综合人影院| 亚洲人成无码网站久久99热国产| 2021久久精品免费观看| 久久99精品国产麻豆蜜芽| 久久综合九色综合久99|