• <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++博客 首頁 新隨筆 聯系 聚合 管理
              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>//使用字符函數
            //isalpha(ch),islower(ch),isdigital(ch)
            //從一個文件中取出字符串與另一個文件比較,計算字符串在該文件中出現的次數
            //(字符串包含匹配性驗證,比如?代表小寫英文字母,*代表小寫英文字母和0-9的數字),
            //第一問要求你用程序實現該題目,第二問要求你對第一問中的程序寫測試用例,包括基本
            //測試、邊界測試,*代表小寫英文字母和0-9的數字
            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;//次數初始為0
               char ch;
               if(fopen(argv[2],"r") != NULL)
               //在文件2中查找字符串,并計數
               {
                 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) //字符串匹配到尾部,成功,總數加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;
            }
            /*邊界測試
            設計測試用例時要考慮邊界輸入和非法輸入,這里統稱為特殊輸入,程序

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

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

            posted on 2009-05-23 10:45 ivy-jie 閱讀(728) 評論(0)  編輯 收藏 引用 所屬分類: MFC
            久久久精品2019免费观看| 91久久成人免费| 久久综合九色综合久99| 久久毛片一区二区| 欧美激情精品久久久久久久九九九| 久久国产高清字幕中文| 热99re久久国超精品首页| 99精品久久精品一区二区| 久久香蕉超碰97国产精品| 97久久久久人妻精品专区| 久久r热这里有精品视频| 94久久国产乱子伦精品免费| 色综合久久综合网观看| 久久久久亚洲精品无码网址| 色婷婷久久久SWAG精品| 久久99九九国产免费看小说| 免费久久人人爽人人爽av| 亚洲狠狠婷婷综合久久久久| 国内精品九九久久久精品| 久久久无码精品亚洲日韩蜜臀浪潮| 狠狠色丁香久久婷婷综| 国产成人AV综合久久| 久久久WWW成人| 久久99久国产麻精品66| 国产V综合V亚洲欧美久久| 久久人妻少妇嫩草AV无码蜜桃| 久久精品国产亚洲αv忘忧草| 久久人人爽人人爽人人片AV不 | 91亚洲国产成人久久精品| 久久精品国产精品亚洲| 99久久99久久精品国产片果冻 | 久久不射电影网| 综合久久精品色| 1000部精品久久久久久久久| 久久夜色撩人精品国产小说| 久久精品中文騷妇女内射| 久久久久久久综合日本| 狠狠色丁香婷婷久久综合不卡 | 久久久国产打桩机| 国产精品热久久毛片| 亚洲精品乱码久久久久久久久久久久|