• <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>

            hdu1075

            What Are You Talking About

            Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 102400/204800 K (Java/Others)
            Total Submission(s): 6842    Accepted Submission(s): 2086


            Problem Description
            Ignatius is so lucky that he met a Martian yesterday. But he didn't know the language the Martians use. The Martian gives him a history book of Mars and a dictionary when it leaves. Now Ignatius want to translate the history book into English. Can you help him?
             

            Input
            The problem has only one test case, the test case consists of two parts, the dictionary part and the book part. The dictionary part starts with a single line contains a string "START", this string should be ignored, then some lines follow, each line contains two strings, the first one is a word in English, the second one is the corresponding word in Martian's language. A line with a single string "END" indicates the end of the directory part, and this string should be ignored. The book part starts with a single line contains a string "START", this string should be ignored, then an article written in Martian's language. You should translate the article into English with the dictionary. If you find the word in the dictionary you should translate it and write the new word into your translation, if you can't find the word in the dictionary you do not have to translate it, and just copy the old word to your translation. Space(' '), tab('\t'), enter('\n') and all the punctuation should not be translated. A line with a single string "END" indicates the end of the book part, and that's also the end of the input. All the words are in the lowercase, and each word will contain at most 10 characters, and each line will contain at most 3000 characters.
             

            Output
            In this problem, you have to output the translation of the history book.
             

            Sample Input
            START from fiwo hello difh mars riwosf earth fnnvk like fiiwj END START difh, i'm fiwo riwosf. i fiiwj fnnvk! END
             

            Sample Output
            hello, i'm from mars. i like earth! 好開心,125ms,statistic里面第三,happying……
            第二個trie,雖然調了老半天,是些字符串處理的錯誤
            wa了兩邊,原因是count是用來判斷有無該單
            #include <cstdio>
            #include 
            <cstdlib>
            #include 
            <cstring>
            #include 
            <cmath>
            #include 
            <ctime>
            #include 
            <cassert>
            #include 
            <iostream>
            #include 
            <sstream>
            #include 
            <fstream>
            #include 
            <map>
            #include 
            <set>
            #include 
            <vector>
            #include 
            <queue>
            #include 
            <algorithm>
            #include 
            <iomanip>
            #define pp printf("here\n")
            using namespace std;
            struct node
            {
                
            int next[26];
                
            char name[11];
                
            int count;
                
            void init()
                
            {
                    memset(next,
            -1,sizeof(next));
                    count
            =0;
                }

            }
             s[5000005];
            int ind,sind;
            void cas_init()
            {
                s[
            0].init();
                sind
            =1;
            }

            void ins(char str[],char str1[])
            {
                
            int len=strlen(str);
                
            int i,j,ind;
                
            for(i=ind=0; i<len; i++)
                
            {
                    j
            =str[i]-'a';
                    
            if(s[ind].next[j]==-1)
                    
            {
                        s[sind].init();
                        s[ind].next[j]
            =sind++;
                    }

                    
            //s[ind].count++;
                    ind=s[ind].next[j];
                }

                s[ind].count
            ++;
                len
            =strlen(str1);
                
            for(i=0; i<len; i++)  s[ind].name[i]=str1[i];
                s[ind].name[len]
            ='\0';
            }

            int search(char str[])
            {
                
            int ind,i,j,len=strlen(str);
                ind
            =0;
                
            for(i=0; i<len; i++)
                
            {
                    j
            =str[i]-'a';
                    
            if(s[ind].next[j]==-1)
                        
            return 0;
                    
            else ind=s[ind].next[j];
                }

                
            return ind;
            }

            int main()
            {
                
            int i,j,len,tmp,ai,k;
                cas_init();
                
            char str[36],str11[15],strn[15];
                
            char str1[1005],str2[10050];
                gets(str);
                
            while(gets(str)&&!(strcmp(str,"END")==0)) 
                
            {
                    len
            =strlen(str);
                    i
            =0;
                    
            while(i<len&&str[i]!=' '{str11[i]=str[i];i++;}str11[i]='\0';
                    i
            ++;
                    j
            =i;
                    
            while(j<len){strn[j-i]=str[j];j++;}strn[j-i]='\0';
                
            //    puts(strn);puts(str11);
                    ins(strn,str11);

                }

                gets(str);
                
            while(gets(str1)&&(strcmp(str1,"END")!=0))
                
            {
                    len
            =strlen(str1);
                    i
            =0;
                    j
            =0;
                    ai
            =0;
                    
            while(j!=len)
                    
            {
                        
            while((str1[i]<'a'||str1[i]>'z')&&(i<len))
                        
            {
                            str2[ai]
            =str1[i];
                            ai
            ++;i++;
                        }

                        j
            =i;
                        
            while(str1[j]<='z'&&str1[j]>='a'&&j<len)
                        
            {
                            strn[j
            -i]=str1[j];
                            j
            ++;
                        }

                        strn[j
            -i]='\0';
                        i
            =j;
                        tmp
            =search(strn);
                        
            if(tmp!=0&&s[tmp].count>0)
                        
            {
                            
            for(k=0; k<strlen(s[tmp].name); k++)
                            
            {
                                str2[ai]
            =s[tmp].name[k];
                                ai
            ++;
                            }

                        }

                        
            else 
                        
            {
                            
            for(k=0;k<strlen(strn);k++)
                            
            {
                                str2[ai]
            =strn[k];
                                ai
            ++;
                            }

                        }

                    }

                    str2[ai]
            ='\0';
                    puts(str2);
                }

                
            return 0;
            }


            posted on 2012-07-16 00:38 jh818012 閱讀(207) 評論(0)  編輯 收藏 引用

            <2025年7月>
            293012345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            導航

            統計

            常用鏈接

            留言簿

            文章檔案(85)

            搜索

            最新評論

            • 1.?re: poj1426
            • 我嚓,,輝哥,,居然搜到你的題解了
            • --season
            • 2.?re: poj3083
            • @王私江
              (8+i)&3 相當于是 取余3的意思 因為 3 的 二進制是 000011 和(8+i)
            • --游客
            • 3.?re: poj3414[未登錄]
            • @王私江
              0ms
            • --jh818012
            • 4.?re: poj3414
            • 200+行,跑了多少ms呢?我的130+行哦,你菜啦,哈哈。
            • --王私江
            • 5.?re: poj1426
            • 評論內容較長,點擊標題查看
            • --王私江
            色8激情欧美成人久久综合电| 97久久精品无码一区二区| 国产精品九九久久精品女同亚洲欧美日韩综合区 | 青青青青久久精品国产h| 精品99久久aaa一级毛片| 中文国产成人精品久久亚洲精品AⅤ无码精品 | 亚洲中文字幕无码久久2020| 久久久久久久亚洲Av无码| 国产精品久久久久久福利69堂| 久久99精品九九九久久婷婷| 99久久夜色精品国产网站| 久久久久国产精品| 亚洲中文字幕无码一久久区| 国产成人精品久久综合| 久久久久亚洲av无码专区导航| 久久福利片| 久久九九全国免费| 欧洲人妻丰满av无码久久不卡| 久久久久国产精品麻豆AR影院| 久久久久国产精品熟女影院| 中文字幕久久精品| 国产精品gz久久久| 91精品婷婷国产综合久久| 日韩精品无码久久久久久| 香蕉aa三级久久毛片| 国产精品久久久久乳精品爆| 国产91久久精品一区二区| 一本色道久久88—综合亚洲精品| 久久免费国产精品| 久久99国产一区二区三区| 狠狠精品干练久久久无码中文字幕| 久久精品人人做人人爽97| 亚洲va久久久噜噜噜久久男同| 久久精品国产欧美日韩99热| 久久精品视频一| 久久久无码精品亚洲日韩京东传媒| 午夜精品久久久久| 久久久久久精品久久久久| 无码AV波多野结衣久久| 97久久香蕉国产线看观看| 久久精品国产亚洲AV嫖农村妇女|