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

            POJ 1318

             1 #include<stdio.h>
             2 #include<string.h>
             3 #include<stdlib.h>
             4 char a[101][7],s[7];
             5 int compare(const void *p,const void *q)
             6 {
             7     return (*(char *)p - *(char *)q);
             8 }
             9 int check(char p[7],char q[7]);
            10 int main()
            11 {
            12     char c[7];
            13     int i,j,flag,n;
            14     i = 0;
            15     while(scanf("%s",&a[i]) && strcmp(a[i],"XXXXXX")){
            16         i++;
            17     }
            18     n = i;
            19     for(i = 0;i < n-1;i++){
            20         for(j = i;j < n;j++){
            21             if(strcmp(a[i],a[j]) > 0){
            22                 strcpy(c,a[i]);
            23                 strcpy(a[i],a[j]);
            24                 strcpy(a[j],c);
            25             }
            26         }
            27     }
            28     while(scanf("%s",s) && strcmp(s,"XXXXXX")){
            29         flag = 1;
            30         for(j = 0;j < n;j++){
            31             if(check(s,a[j])){
            32                 flag = 0;
            33                 printf("%s\n",a[j]);
            34             }
            35         }
            36         if(flag){
            37             printf("NOT A VALID WORD\n");
            38         }
            39         printf("******\n");
            40     }
            41     system("pause");
            42     return 0;
            43 }
            44 int check(char p[7],char q[7])
            45 {
            46     char c[7];
            47     int len1,len2;
            48     int i;
            49     len1 = strlen(p);
            50     len2 = strlen(q);
            51     if(len1 != len2)
            52     return 0;
            53     strcpy(c,q);
            54     qsort(c,len2,sizeof(char),compare);
            55     qsort(p,len1,sizeof(char),compare);
            56     for(i = 0;i < len1;i++){
            57         if(c[i] != p[i]){
            58            return 0;
            59         }
            60     } 
            61     return 1;
            62 }
            63 我在做1318時(shí)遇到過一個(gè)問題,當(dāng)對(duì)字典字符串排序時(shí)不能用qsort,因?yàn)樗粚?duì)各個(gè)字符串首字母進(jìn)行排序,比如:輸入Sample Input 中的tarp,trap,用aptr查時(shí)結(jié)果卻是trap在前面。但是如果是用C++則可直接調(diào)用sort對(duì)字典進(jìn)行排序。沒辦法,只有自己編了,19~27行,用了一般的排序方法,兩個(gè)for循環(huán),時(shí)間達(dá)到了O(n^2),但是竟然是0MS,AC。我想可能是因?yàn)轭}目把字典字符串?dāng)?shù)限制在100以內(nèi)吧,數(shù)量不大。

            posted on 2009-04-22 22:36 Johnnx 閱讀(322) 評(píng)論(0)  編輯 收藏 引用


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            導(dǎo)航

            <2009年4月>
            2930311234
            567891011
            12131415161718
            19202122232425
            262728293012
            3456789

            統(tǒng)計(jì)

            常用鏈接

            留言簿(1)

            隨筆檔案

            搜索

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            国产69精品久久久久99| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 久久99精品久久久久久不卡| 成人精品一区二区久久久| 性做久久久久久久久老女人| 国产精品美女久久久久久2018| 久久久久久国产精品免费免费 | 久久综合色区| 97r久久精品国产99国产精| 久久久久无码中| av国内精品久久久久影院| 久久婷婷色香五月综合激情| 久久本道伊人久久| 狠狠色婷婷久久综合频道日韩| 青青青伊人色综合久久| 亚洲AV成人无码久久精品老人 | 久久国产精品无| 国产综合精品久久亚洲| 久久精品亚洲中文字幕无码麻豆 | 亚洲国产成人精品女人久久久| 青青草原精品99久久精品66| 综合久久精品色| 欧美成a人片免费看久久| 蜜桃麻豆www久久| 国产V综合V亚洲欧美久久| 欧美牲交A欧牲交aⅴ久久| 亚洲欧美伊人久久综合一区二区 | 国产精品久久久久9999| 久久一日本道色综合久久| 国产偷久久久精品专区| 精品久久久久久久久免费影院| 久久黄色视频| 无码精品久久一区二区三区| 久久久人妻精品无码一区 | 香蕉久久久久久狠狠色| 亚洲欧美日韩精品久久亚洲区 | 久久久久国产精品嫩草影院| 久久精品国产亚洲7777| 日日狠狠久久偷偷色综合免费 | 亚洲国产成人久久综合区| 久久亚洲国产成人影院|