• <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 閱讀(238) 評論(0)  編輯 收藏 引用
             
            Copyright © Leon916 Powered by: 博客園 模板提供:滬江博客
            亚洲国产精品无码久久98| 精品人妻久久久久久888| 国产A级毛片久久久精品毛片| 99热都是精品久久久久久| 久久久黄片| 亚洲国产另类久久久精品黑人| 亚洲国产精品无码久久久久久曰 | 久久久久亚洲精品中文字幕| 久久成人小视频| 精品久久久久久| 国产69精品久久久久久人妻精品| 99久久99这里只有免费的精品| 久久人妻少妇嫩草AV蜜桃| 久久国产色AV免费看| 欧美久久亚洲精品| 色综合久久综合网观看| 国内精品久久久久久久久电影网 | 一本一道久久a久久精品综合 | 久久亚洲中文字幕精品一区四| 亚洲精品无码久久久久去q | 亚洲国产精品无码久久久秋霞2| 久久激情五月丁香伊人| 国产成人精品久久免费动漫| 国产成人久久精品一区二区三区| 精品乱码久久久久久夜夜嗨| 四虎国产精品免费久久久| 国产精品久久久久久福利漫画| 伊人久久大香线蕉AV色婷婷色| 欧美日韩成人精品久久久免费看| 色综合久久天天综合| 国产精品99久久不卡| 婷婷综合久久狠狠色99h| 久久精品国产亚洲AV无码麻豆| 亚洲精品无码久久一线| 亚洲精品无码久久久影院相关影片| 97精品依人久久久大香线蕉97| 亚洲国产精品无码久久青草| 久久国产亚洲精品| 久久精品国产AV一区二区三区| 免费无码国产欧美久久18| 久久久国产打桩机|