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

            ivy-jie

            progress ...

            C++博客 首頁 新隨筆 聯(lián)系 聚合 管理
              9 Posts :: 41 Stories :: 6 Comments :: 0 Trackbacks

            #include <stdio.h>
            #include <stdlib.h>
            #include <string.h>
            #include <iostream.h>  //for cout
            #include <ctype.h>//使用字符函數(shù)
            //isalpha(ch),islower(ch),isdigital(ch)
            //從一個文件中取出字符串與另一個文件比較,計算字符串在該文件中出現(xiàn)的次數(shù)
            //(字符串包含匹配性驗證,比如?代表小寫英文字母,*代表小寫英文字母和0-9的數(shù)字),
            //第一問要求你用程序?qū)崿F(xiàn)該題目,第二問要求你對第一問中的程序?qū)憸y試用例,包括基本
            //測試、邊界測試,*代表小寫英文字母和0-9的數(shù)字
            bool equal(char a,char b)
            {
              if(a==b) return true;
              if(a == '?' && b == '*' || a=='*' && b=='?')
               return true;
              if((a=='?' && b>=97 && b<=122) || (a>=97 && a<=123 && b=='?'))
               return true;
              if((a=='*' && b>=97 && b<=122) || (a>=97 && a<=122 && b=='*') || (a=='*' && b>=48 &&b<=57) || (a>=48 && a<=57 && b=='*'))
               return true;
              return false;
            }
            int main(int argc,char** argv)
            {
              char line[30];
              FILE *fp;
              int i=0,j=0;
              if((fp = fopen(argv[1],"r")) != NULL)
              {
               if(fgets(line,100,fp)== NULL)//實際上取29個字符,最后加'\0'
               {
                printf("fgets error\n");
               }
               fclose(fp);
              }
             
               int length = strlen(line);
               int sum = 0;//次數(shù)初始為0
               char ch;
               if(fopen(argv[2],"r") != NULL)
               //在文件2中查找字符串,并計數(shù)
               {
                 while((ch = fgetc(fp))!= EOF)
              {
                int test;
                   test = ftell(fp);
                printf("file pointer value:%d\n",test);
                if(equal(ch,line[j]))
                {
                 j++;
                 if(j == length) //字符串匹配到尾部,成功,總數(shù)加1
                 {
                  sum+=1;
                  j =0;
                 }
                }

                else           //否則的話回溯,重新匹配
                {
                 i= ftell(fp);
                 fseek(fp,j,1);//向前回溯一個字符
                 j= 0;
                }
             }
               }
                printf("string %s occurs %d times in file2\n",line,sum);
                return sum;
            }
            /*邊界測試
            設計測試用例時要考慮邊界輸入和非法輸入,這里統(tǒng)稱為特殊輸入,程序

            員在編寫代碼時也要考慮特殊輸入,要為特殊輸入編寫處理代碼。在實際工作中,程序員沒有考慮到某些

            特殊輸入是很常見的,這也是程序錯誤的一個重要來源。
            */

            posted on 2009-05-23 10:45 ivy-jie 閱讀(729) 評論(0)  編輯 收藏 引用 所屬分類: MFC
            亚洲色婷婷综合久久| WWW婷婷AV久久久影片| 久久精品夜色噜噜亚洲A∨| 99久久99久久精品国产片果冻| 久久亚洲国产欧洲精品一| 久久国产成人午夜aⅴ影院 | 久久国产乱子伦精品免费午夜| 欧美激情精品久久久久| 亚洲国产精品嫩草影院久久| 久久精品亚洲日本波多野结衣| 国产亚洲精久久久久久无码AV| 亚洲午夜久久久影院伊人| 91精品国产色综久久| 无码AV波多野结衣久久| 久久无码中文字幕东京热| 国产成人久久AV免费| 久久天天躁夜夜躁狠狠躁2022| 热久久国产精品| 久久棈精品久久久久久噜噜| 青青热久久国产久精品 | 亚洲国产成人精品久久久国产成人一区二区三区综 | 少妇高潮惨叫久久久久久| 久久久久这里只有精品 | 久久久久久国产a免费观看不卡| 欧洲人妻丰满av无码久久不卡| 亚洲?V乱码久久精品蜜桃| 国产午夜福利精品久久| 久久福利青草精品资源站免费| 99精品久久久久久久婷婷 | 久久久久国产精品嫩草影院 | 国内精品久久久久久久影视麻豆| 亚洲日本va中文字幕久久| 久久国产免费直播| 性高朝久久久久久久久久| 久久一区二区三区99| 久久久WWW免费人成精品| 久久久久亚洲AV无码专区网站 | 久久精品人妻中文系列| 九九精品久久久久久噜噜| 国色天香久久久久久久小说| 狠狠色丁香久久婷婷综合图片 |