青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

ACM___________________________

______________白白の屋
posts - 182, comments - 102, trackbacks - 0, articles - 0
<2010年8月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
2930311234

常用鏈接

留言簿(24)

隨筆分類(332)

隨筆檔案(182)

FRIENDS

搜索

積分與排名

最新隨筆

最新評論

閱讀排行榜

評論排行榜

MiYu原創, 轉帖請注明 : 轉載自 ______________白白の屋    

 

這幾天一直很YM..... 糾結.....  做個水題 1075......WA N次.....YM.
(  很簡單的一題,  檢索輸入的串是否存在, 存在就替換輸出, 不存在直接輸出就可以了 )
最后無奈, 純C++ STL..過了, 時間竟然用了 1600+MS 還是 C++交的,  G++要3400+MS,  不
明白為什么時間差那么多,  用trie 做了次, 250MS...   改了好幾次效率都上不來   ....  YM 中 把trie 寫成了 偽 map ,只有一點簡單的功能,
其他的不想寫了.  寫得好復雜.................... 
偽 map 代碼如下 :  好長.....................
/*
MiYu原創, 轉帖請注明 : 轉載自 ______________白白の屋
          http://www.cnblog.com/MiYu
Author By : MiYu
Test      : 4
Program   : 1075
*/

#include <iostream>
#include <string>
using namespace std;
typedef struct dict DIC;
DIC *root = NULL;
string ext = "";
struct dict {
       dict (){ str = "";memset ( child , 0 , sizeof ( child ) ); }
       ~dict () { }
       void del ( DIC * node );
       string & insert ( char *ins,char *key = NULL );
       string & find ( char *ins );
       string & operator [] ( char *a );
       string & operator = ( char *a );
       DIC *child[26];
       string str; 
};
void dict::del ( DIC * node )
{
     if ( node == NULL ) return;
     for ( int i = 0; i != 26; ++ i )
     {
          if ( node->child[i] != NULL )  del ( node->child[i] );
     }
     node->str = "";
     free ( node );  
}
string & dict::operator [] ( char *a )
{
       string &str = find ( a );
       if ( str == "" )
           return  insert ( a );  
       return str;
}
string & dict::operator = ( char *a )
{
      return this->str = a; 
}
string & dict::insert ( char *ins,char *key )
{
            DIC *cur = this,*now;
            int len = strlen ( ins );
            for ( int i = 0; i != len; ++ i )
            {
                  if ( cur->child[ ins[i] - 'a' ] != NULL ) 
                  {
                       cur = cur->child[ ins[i] - 'a' ];
                  }
                  else
                  {
                       now = new DIC;
                       cur->child[ ins[i] - 'a' ] = now;
                       cur = now;
                  }
            } 
            return cur->str;
}
string & dict::find ( char *ins )
{
            DIC *cur = this;
            int len = strlen ( ins );
            for ( int i = 0; i != len; ++ i )
            {
                 if ( cur->child[ ins[i] - 'a' ] != NULL )
                      cur = cur->child[ ins[i] - 'a' ];  
                 else
                      return ext; 
            } 
            return cur->str;
}
char words[3010],temp[12],t[12];
int main ()
{
    DIC dict;
    root = &dict;
    scanf ( "%s", t );
    while ( scanf ( "%s", t ), strcmp ( t, "END" ) != 0 )
    {
           scanf ( "%s", temp );
           dict[temp] = t;
    }
    scanf ( "%s", t );
    getchar();
    while ( gets ( words ) && strcmp ( words, "END" ) != 0 )
    {
           memset ( temp, 0, sizeof ( temp ) );
           int len = strlen ( words );
           for ( int i = 0,j = 0; i != len; ++ i )
           {
                if ( isalpha ( words[i] ) )
                {
                     temp[j++] = words[i];
                } 
                else 
                {
                     temp[j] = '\0';
                     string str = dict[ temp ];
                     if ( str == "" )
                          printf ( "%s",temp ); 
                     else
                          printf ( "%s",str.c_str() );
                     putchar ( words[i] );
                     j = 0; 
                }
           }
           putchar ( 10 );
    }
    return 0;
}

 

 STL 代碼如下 :  好短....

 /*

MiYu原創, 轉帖請注明 : 轉載自 ______________白白の屋

          http://www.cnblog.com/MiYu

Author By : MiYu

Test      : 1

Program   : 1075

*/


#include <iostream>

#include <string>

#include <map>

using namespace std;

string words,temp;

map < string , string > mp;

int main ()

{

    cin >> words;

    while ( cin >> words, words != "END" )

    {

           cin >> temp;

           mp[ temp ] = words;

    }

    cin >> words;

    getchar();

    while ( getline ( cin, words ) && words != "END" )

    {

           string out = "";

           int len = words.size();

           for ( int i = 0; i != len; ++ i )

           {

                if ( isalpha ( words[i] ) )

                {

                     out += words[i];

                } 

                else 

                {

                     if ( mp[out] == "" )

                          cout << out; 

                     else

                          cout << mp[out];

                     cout << words[i];

                     out = ""; 

                }

           }

           cout << endl;

    }

    return 0;

}


 

 

 

 

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲精品永久免费精品| 亚洲国产二区| 午夜精品久久久久久久| 国产精品久久久久久久久借妻| 一本久道久久久| 亚洲国产免费看| 欧美刺激性大交免费视频| 久久综合中文| 国产精品入口夜色视频大尺度| 亚洲国产成人午夜在线一区| 欧美大片一区二区三区| 欧美刺激午夜性久久久久久久| 日韩一级不卡| 亚洲免费视频在线观看| 国内精品久久久久影院 日本资源 国内精品久久久久伊人av | 久久人人九九| 女人香蕉久久**毛片精品| 亚洲免费成人av| 亚洲欧美日韩综合aⅴ视频| 樱桃成人精品视频在线播放| 亚洲欧洲日本一区二区三区| 国产精品色午夜在线观看| 久久阴道视频| 欧美日韩影院| 久久综合久久综合久久| 欧美日本在线看| 久久久久国产精品麻豆ai换脸| 久色婷婷小香蕉久久| 亚洲自拍偷拍视频| 蜜桃精品一区二区三区 | 国产精品自拍小视频| 免费一级欧美片在线播放| 欧美亚州韩日在线看免费版国语版| 欧美在线精品免播放器视频| 欧美国产日本在线| 久久久www成人免费无遮挡大片| 欧美大片在线观看一区二区| 久久狠狠亚洲综合| 欧美日韩一区二区三区四区在线观看| 久久精品国产免费看久久精品| 欧美另类综合| 蜜桃av一区| 国产欧美日韩一区二区三区在线观看| 亚洲国产精品一区二区第四页av| 国产区日韩欧美| 在线一区二区三区四区五区| 亚洲精品欧美日韩专区| 欧美一区二区三区久久精品茉莉花| 9色精品在线| 欧美承认网站| 欧美激情视频给我| 狠狠做深爱婷婷久久综合一区| 亚洲一级片在线观看| 国产欧美三级| 一区二区三区精品国产| 91久久综合亚洲鲁鲁五月天| 久久久久久穴| 久久最新视频| 国产专区欧美专区| 亚洲欧美一区二区激情| 亚洲欧美中日韩| 国产精品sm| 宅男在线国产精品| 亚洲午夜一二三区视频| 欧美日韩另类国产亚洲欧美一级| 亚洲茄子视频| 一区二区三区免费网站| 欧美日韩亚洲一区二区三区| 日韩视频免费| 亚洲欧美在线免费| 国产日韩欧美亚洲| 午夜视频一区在线观看| 久久成人国产| 韩国免费一区| 久久午夜激情| 亚洲欧洲精品成人久久奇米网| 亚洲激情自拍| 欧美激情二区三区| 99爱精品视频| 先锋a资源在线看亚洲| 国产精品国色综合久久| 亚洲欧美国产日韩天堂区| 久久动漫亚洲| 精品91免费| 欧美啪啪成人vr| 在线综合视频| 久久深夜福利免费观看| 韩日精品在线| 欧美激情一区二区三区在线视频| 亚洲美女中文字幕| 欧美有码视频| 亚洲破处大片| 国产精品人人做人人爽| 久久精品成人一区二区三区| 亚洲国产91| 欧美一区二区在线免费观看| 亚洲成在线观看| 欧美日韩亚洲国产一区| 午夜精品一区二区在线观看| 欧美国产国产综合| 亚洲欧美日韩国产一区二区三区| 国产一区激情| 欧美日韩卡一卡二| 久久九九精品| 一本色道久久综合狠狠躁篇怎么玩 | 欧美日韩国内自拍| 午夜亚洲性色视频| 亚洲黄色高清| 久久精品青青大伊人av| 日韩视频一区二区在线观看| 国产日韩欧美成人| 欧美激情一区二区三区高清视频| 午夜精品久久久久久久99黑人| 亚洲福利免费| 久久久久久有精品国产| 亚洲视频精选| 亚洲电影在线观看| 国产精品一区二区久久久| 欧美激情欧美狂野欧美精品| 欧美一区二区三区免费视频| 99精品欧美一区| 亚洲成人资源| 一区二区三区高清| 在线观看国产成人av片| 国产欧美一区二区三区久久| 欧美另类亚洲| 欧美国产精品v| 久久伊人精品天天| 欧美一级黄色录像| 亚洲免费在线电影| 夜夜嗨av一区二区三区免费区| 欧美黄色免费网站| 另类专区欧美制服同性| 欧美在线视频播放| 亚洲欧美日韩一区二区三区在线| 亚洲精选在线观看| 亚洲经典三级| 亚洲青色在线| 亚洲人成7777| 亚洲精品乱码久久久久久久久| 亚洲第一综合天堂另类专| 国产在线一区二区三区四区| 国产欧美亚洲日本| 国产日韩欧美在线视频观看| 国产精品视频网址| 国产精品一区二区在线观看不卡 | 国产精品swag| 国产精品久久国产三级国电话系列| 欧美精品久久久久久久免费观看| 欧美激情精品久久久久久黑人 | 一本大道av伊人久久综合| 亚洲人成网站在线观看播放| 亚洲国产精品高清久久久| 欧美激情91| 亚洲片区在线| 一区二区毛片| 亚洲欧美日韩天堂一区二区| 亚洲欧美日韩在线播放| 欧美一区二区三区婷婷月色| 久久精品国产999大香线蕉| 久久精品国产99精品国产亚洲性色 | 亚洲综合色在线| 香蕉久久夜色精品国产| 久久精品盗摄| 欧美电影美腿模特1979在线看| 欧美大片在线看免费观看| 欧美色图首页| 国产一区二区久久| 亚洲福利电影| 亚洲综合三区| 麻豆乱码国产一区二区三区| 亚洲国产高清在线| 亚洲视频一区二区| 久久国产一区二区三区| 麻豆久久精品| 国产精品久久网| 欧美精品一区二区在线播放| 欧美系列一区| 136国产福利精品导航网址应用 | 亚洲激情女人| 亚洲男人第一av网站| 老司机午夜免费精品视频| 亚洲国产精品久久久久秋霞影院| 在线视频精品一| 久久婷婷综合激情| 国产精品第2页| 亚洲国产美女| 欧美一区二区精品在线| 亚洲黄色三级| 欧美在线视频观看免费网站| 欧美精品亚洲一区二区在线播放| 国产三级欧美三级| 日韩性生活视频| 久久综合伊人77777尤物| 亚洲天堂av电影| 欧美精品乱码久久久久久按摩| 国产在线欧美日韩| 亚洲一区免费视频| 亚洲黄色视屏| 久久嫩草精品久久久精品|