• <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>
            Welcome to Leon's Blog  
            日歷
            <2008年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567
            統計
            • 隨筆 - 30
            • 文章 - 0
            • 評論 - 51
            • 引用 - 0

            導航

            常用鏈接

            留言簿(4)

            隨筆分類

            隨筆檔案

            ACM

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

             

            今天下午做了一道acm的題,提交了10次都是WA,所以想請大家幫我看看到底哪里不正確,程序哪里寫的不好!謝謝大家了!
            代碼:

              1#include <stdlib.h>
              2#include <stdio.h>
              3typedef struct telNumber
              4{
              5 int fNumber;
              6 int lNumber;
              7 int count;
              8}
             TelNumber;
              9
             10int toNumber[26= {2,2,2,3,3,3,4,4,4,5,5,5,6,6,6,7,-1,7,7,8,8,8,9,9,9,-1};
             11
             12int  ConvertToNumber(char *ch, TelNumber *temp)
             13{
             14 int tmp;
             15 tmp = 0;
             16
             17 if!ToNumber(ch, &tmp, 7))
             18
             19  return 0;
             20
             21 temp->fNumber = tmp/10000;
             22 temp->lNumber = tmp%10000;
             23 temp->count = 1;
             24
             25 return 1;
             26
             27}

             28
             29int  ToNumber(char *c, int *number,int count)
             30{
             31
             32 int tmp = 0;
             33 int i;
             34 for( i = 0; i < count; )
             35 {
             36
             37    if*== '-')
             38
             39    {
             40        c++;
             41   continue;
             42  }

             43
             44  else if*>= '0' && *<= '9')
             45  {
             46   tmp = tmp*10 + (*c) - '0';
             47  }

             48  else if(*>= 'A' && *<= 'Z')
             49  {
             50   if(toNumber[*c-'A'> 0)
             51   {
             52    tmp = tmp * 10 + toNumber[*c-'A'];
             53   }

             54   else
             55    return 0;
             56  }

             57  else
             58   return 0;
             59  i++;
             60  c++;
             61
             62 }

             63 *number = tmp;
             64 return 1;
             65
             66}

             67void SortNumber(TelNumber **tel, int left, int right)
             68{
             69 int p;
             70
             71 if(left >= right)
             72  return;
             73 
             74 p = Partition(tel,left, right);
             75 SortNumber(tel, left, p-1);
             76 SortNumber(tel, p+1, right);
             77
             78}

             79int Partition(TelNumber **tel, int left, int right)
             80{
             81 int j = left + 1;
             82 int i;
             83
             84 TelNumber *temp = tel[(left+right)/2];
             85 tel[(left+right)/2= tel[left];
             86 tel[left] = temp;
             87
             88 
             89 for( i = j; i <= right; i++)
             90 {
             91  if(tel[i]->fNumber < tel[left]->fNumber || (tel[i]->fNumber == tel[left]->fNumber && tel[i]->lNumber <= tel[left]->lNumber))
             92  {
             93   temp = tel[i];
             94   tel[i] = tel[j];
             95   tel[j] = temp;
             96   j++;
             97  }

             98 }
             
             99
            100 temp = tel[j-1];
            101 tel[j-1= tel[left];
            102 tel[left ] = temp;
            103 return j -1;
            104}

            105int Combinate(TelNumber **tel, int count)
            106{
            107 int t = 0;
            108 int i;
            109 for( i = 0; i < count;)
            110 {
            111  int j = i+1;
            112  while(j < count)
            113  {
            114   if(tel[i]->fNumber == tel[j]->fNumber && tel[i]->lNumber == tel[j]->lNumber)
            115   {
            116    j++;
            117   }

            118   else 
            119    break;
            120  }
             
            121
            122  tel[i]->count = j-i;
            123  tel[t] = tel[i];
            124  t++;
            125  i = j;
            126 }

            127 return t;
            128}

            129
            130int main(int argc, char* argv[])
            131{
            132
            133 int count;
            134 int p = 0;
            135 int tc = 0;
            136 int i;
            137 int t;
            138 TelNumber **tel;
            139 scanf("%d"&count);
            140 tel = (TelNumber**) malloc(sizeof(TelNumber*)*count);
            141 for( i = 0; i < count; i++)
            142 {
            143  char ch[100];
            144  TelNumber *temp = (TelNumber*)malloc(sizeof(TelNumber)); 
            145  temp->fNumber = 0;
            146  temp->count = 0;
            147  temp->lNumber = 0;
            148  scanf("%s", ch);
            149  if(!ConvertToNumber(ch, temp))
            150   continue;
            151  tel[tc++= temp;
            152 }

            153
            154 SortNumber(tel, 0, tc-1);
            155 t = Combinate(tel, tc);
            156 if(t == tc)
            157 {
            158  printf("No duplicates.\n");
            159 }

            160 else
            161 {
            162  for( i = 0; i < t; i++)
            163  {
            164   if(tel[i]->count > 1)
            165   {
            166    printf("%d-%d %d\n",tel[i]->fNumber,tel[i]->lNumber,tel[i]->count);
            167   }

            168  }

            169 }

            170 return 0;
            171}

            172
            173


            posted on 2008-05-15 19:29 Leon916 閱讀(231) 評論(0)  編輯 收藏 引用
             
            Copyright © Leon916 Powered by: 博客園 模板提供:滬江博客
            97精品依人久久久大香线蕉97 | 久久综合久久综合九色| 一本色道久久88精品综合 | 久久国产乱子伦精品免费强| 久久九九全国免费| 久久亚洲av无码精品浪潮| 一本一道久久综合狠狠老| 久久综合中文字幕| 久久久久免费精品国产| 伊人久久综合热线大杳蕉下载| 亚洲精品国产自在久久| 国产精品久久久久久搜索| 亚洲欧美国产日韩综合久久| av国内精品久久久久影院| 伊人久久大香线蕉无码麻豆| 香蕉久久一区二区不卡无毒影院| 亚洲精品WWW久久久久久| 97久久精品人人做人人爽| 亚洲AV成人无码久久精品老人 | A级毛片无码久久精品免费| 国产精品免费看久久久香蕉| 色诱久久久久综合网ywww| 午夜精品久久影院蜜桃| 99久久国产亚洲高清观看2024| 人妻精品久久无码专区精东影业| 色播久久人人爽人人爽人人片aV| 天天久久狠狠色综合| 久久久久久毛片免费播放| 狠狠综合久久综合88亚洲| 欧美精品九九99久久在观看| 久久国产精品二国产精品| 91麻精品国产91久久久久| 一本大道久久a久久精品综合| 国产麻豆精品久久一二三| 久久久亚洲欧洲日产国码二区| 中文字幕乱码久久午夜| 人妻无码精品久久亚瑟影视| 久久婷婷色综合一区二区| 天天做夜夜做久久做狠狠| 中文字幕精品久久| 77777亚洲午夜久久多人|