pku 1002 解题报告

题目要求是对已经给出的:

A, B, and C map to 2
D, E, and F map to 3
G, H, and I map to 4
J, K, and L map to 5
M, N, and O map to 6
P, R, and S map to 7
T, U, and V map to 8
W, X, and Y map to 9
的一系列的电话号码先进行格式化的转换为形如xxx-xxxx的电话号码。

然后进行排序,最后统计出现了两次以上的电话号码。

解题方法:字符串处理+排序+统计。难度:简单。

代码:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
  
  char map[] = "22233344455566677778889999"; //map其他的代码中学到的 比较方便
  char str[80], telNumbers[100000][9]; //数组虽然开大了 不过尽量大吧
   
 int compare(const void *elem1,const void *elem2)
 {
   return (strcmp((char*)elem1, (char*)elem2));

 }
 void chagee(char str[],int k)//规范化
 {
  int i,j=0,lstr;
  lstr=strlen(str);
  for(i=0;i<lstr;i++)
  {
   if(str[i]=='-')
    continue;
   else
   {
    if(j==3)
    {
     telNumbers[k][3]='-';
     i--;
     j++;
     continue;
    }
    if(str[i]>='A' && str[i]<='Z')
     telNumbers[k][j++]=map[str[i]-'A'];
    else
     if(str[i]>='0' && str[i]<='9')
      telNumbers[k][j++]=str[i];

   }

  }
  telNumbers[k][j]='/0';

 }
 
 int main()
 {
  int j,i,flag,ss;
  scanf("%d",&j);
  for(i=0;i<j;i++)
  {
   scanf("%s",str);
   chagee(str,i);
  }
  qsort(telNumbers,j,9,compare);
 
  i=0;
 flag=0;
   while(i<j)//统计相同的个数 因为已经排序了 所以可以这么进行,做的时候犯二了 没有注意到已经排好序,导致TLE一次
   {
    ss=i;
    i++;
   while(i<j && strcmp(telNumbers[i], telNumbers[ss])==0)
    i++;
    if(i-ss>1)
 {
  printf("%s %d/n", telNumbers[ss], i-ss);
  flag=1;
    }
   }
   if ( !flag )
    printf("No duplicates./n");

 
  return 0;

 }

 

AC TIME:500MS。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值