• <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>//使用字符函數
            //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;
            }
            /*邊界測試
            設計測試用例時要考慮邊界輸入和非法輸入,這里統(tǒng)稱為特殊輸入,程序

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

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

            posted on 2009-05-23 10:45 ivy-jie 閱讀(723) 評論(0)  編輯 收藏 引用 所屬分類: MFC
            91精品国产综合久久香蕉| 无码人妻精品一区二区三区久久| 无码国内精品久久人妻| 久久精品亚洲AV久久久无码| 久久人人爽人人爽人人片av高请| avtt天堂网久久精品| 久久亚洲国产成人影院网站| 久久精品国产亚洲av麻豆蜜芽 | 亚洲欧美精品伊人久久| 欧美日韩精品久久久免费观看| 亚洲精品无码成人片久久| www亚洲欲色成人久久精品| 伊人久久大香线蕉综合5g| 亚洲成人精品久久| 亚洲精品蜜桃久久久久久| 久久国产成人| 国产福利电影一区二区三区久久老子无码午夜伦不 | 无遮挡粉嫩小泬久久久久久久| 久久99精品久久久久久久不卡| 久久精品一区二区影院| 精品久久久久久久无码| 久久婷婷色香五月综合激情| 久久99精品久久只有精品| 国产亚洲成人久久| 99久久无码一区人妻a黑| 亚洲精品无码久久毛片| 国产福利电影一区二区三区久久久久成人精品综合 | 欧美精品九九99久久在观看| 国产综合免费精品久久久| 99麻豆久久久国产精品免费| 少妇久久久久久久久久| 三级三级久久三级久久| 亚洲精品久久久www| 亚洲国产精品无码久久九九| 日本加勒比久久精品| 亚洲国产精品综合久久一线| 香蕉久久永久视频| 中文成人无码精品久久久不卡 | 久久午夜免费视频| 国产成人久久精品一区二区三区| 精品国产91久久久久久久a|