P2037 电话号码
题目描述
一串由长长的数字组成的电话号码通常很难记忆。为了方便记忆,有种方法是用单词来方便记忆。例如用“Three Tens”来记忆电话3-10-10-10。
电话号码的标准形式是七位数字,中间用连字号分成前三个和后四个数字(例如:888-1200)。电话号码可以用字母来表示。以下是字母与数字的对应:
A,B和C对应2
D,E和F对应3
G,H和I对应4
J,K和L对应5
M,N和O对应6
P,R和S对应7
T,U和V对应8
W,X和Y对应9
你会发现其中没有字母Q和Z。电话中的连字号是可以忽略。例如TUT-GLOP的标准形式是888-4567,310-GINO的标准形式是310-4466,3-10-10-10的标准形式是310-1010。
如果两个电话号码的标准形式是一样的,那么这两个电话号码就是一样的。
现在有一本电话簿,请从中找出哪些电话号码是重复的。
输入输出格式
输入格式:
第一行一个正整数N,表示有多少个电话号码。
以下N行,每行一个电话号码,电话号码由数字、大写字母(除Q、Z)和连字符组成。电话号码长度不会超过1000。所有电话号码都合法。
输出格式:
将所有重复的电话号码按字典序以标准形式输出,并且在每个电话号码后跟一个整数,表示该电话号码共出现了多少次,电话号码和整数间用一个空格隔开。不要输出多余空行。
如果没有重复的电话号码,则输出:No duplicates.
输入输出样例
说明
【数据范围】
对于30%的数据,N<=20。
对于50%的数据,N<=10000。
对于100%的数据,N<=100000。
不用开map
/*用一个map把所有的字母表示的数字存起来,0和1题目中没说,但也要表示。
一个<string,int>类型的map表示a这个字符串出现的次数。
把每个读入的字符串转化为标准形式存起来,如果有出现次数超过两次的,存起来,答案数++。
最后将答案按字典序排序输出。 (如果map的初始化写到了函数里,别忘记调用!!!,一开始没调用,全输出的空格,调了半个多小时)。*/ #include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<map>
#include<string>
using namespace std; int n,cnt,now,pos,sum[];
string s,temp,tot[];
map<char,char> excel;
map<string,int> a;
struct Ans
{
int cs;
string chuan;
}ans[]; void init() //初始化函数
{
excel['']='';excel['']='';
excel['A']=excel['B']=excel['C']=excel['']='';
excel['D']=excel['E']=excel['F']=excel['']='';
excel['G']=excel['H']=excel['I']=excel['']='';
excel['J']=excel['K']=excel['L']=excel['']='';
excel['M']=excel['N']=excel['O']=excel['']='';
excel['P']=excel['R']=excel['S']=excel['']='';
excel['T']=excel['U']=excel['V']=excel['']='';
excel['W']=excel['X']=excel['Y']=excel['']='';
} bool cmp(Ans a,Ans b)
{
return a.chuan+b.chuan<b.chuan+a.chuan;
} int main()
{
init(); //千万千万别忘记调用
scanf("%d",&n);
for(int i=;i<=n;i++)
{
cin>>s;
temp.clear();pos=; //将temp清空,pos归零
for(int j=;j<s.length();j++)
{
if(s[j]!='-') //转化为数字
{
temp+=excel[s[j]];
pos++;
}
if(pos==) temp+='-',pos=-; //到了该加'-'的地方,加上'-',同时将pos设为负值,防止重复添加
}
if(!a[temp]) tot[++cnt]=temp; //如果这个字符串没出现过,将这个字符串加入到已有的字符串中
a[temp]++; //该字符串出现的次数++
}
for(int i=;i<=cnt;i++) //找哪个字符串是重复的
{
if(a[tot[i]]>)
{
ans[++now].chuan=tot[i]; //存答案
ans[now].cs=a[tot[i]];
}
}
if(!now) //没有重复的
{
printf("No duplicates.");
return ;
}
sort(ans+,ans+now+,cmp); //按字典序排列
for(int i=;i<=now;i++)
{
cout<<ans[i].chuan<<' ';
printf("%d\n",ans[i].cs);
}
return ;
}
map TLE一个点
/*用一个map把所有的字母表示的数字存起来,0和1题目中没说,但也要表示。
一个<string,int>类型的map表示a这个字符串出现的次数。
把每个读入的字符串转化为标准形式存起来,如果有出现次数超过两次的,存起来,答案数++。
最后将答案按字典序排序输出。 (如果map的初始化写到了函数里,别忘记调用!!!,一开始调用,全输出的空格,调了半个多小时)。*/ #include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<map>
#include<string>
using namespace std; int n,cnt,now,pos,sum[];
string s,temp,tot[];
char excel[];
map<string,int> a;
struct Ans
{
int cs;
string chuan;
}ans[]; void init() //初始化函数
{
excel['']='';excel['']='';
excel['A']=excel['B']=excel['C']=excel['']='';
excel['D']=excel['E']=excel['F']=excel['']='';
excel['G']=excel['H']=excel['I']=excel['']='';
excel['J']=excel['K']=excel['L']=excel['']='';
excel['M']=excel['N']=excel['O']=excel['']='';
excel['P']=excel['R']=excel['S']=excel['']='';
excel['T']=excel['U']=excel['V']=excel['']='';
excel['W']=excel['X']=excel['Y']=excel['']='';
} bool cmp(Ans a,Ans b)
{
return a.chuan+b.chuan<b.chuan+a.chuan;
} int main()
{
init(); //千万千万别忘记调用
scanf("%d",&n);
for(int i=;i<=n;i++)
{
cin>>s;
temp.clear();pos=; //将temp清空,pos归零
for(int j=;j<s.length();j++)
{
if(s[j]!='-') //转化为数字
{
temp+=excel[s[j]];
pos++;
}
if(pos==) temp+='-',pos=-; //到了该加'-'的地方,加上'-',同时将pos设为负值,防止重复添加
}
if(!a[temp]) tot[++cnt]=temp; //如果这个字符串没出现过,将这个字符串加入到已有的字符串中
a[temp]++; //该字符串出现的次数++
}
for(int i=;i<=cnt;i++) //找哪个字符串是重复的
{
if(a[tot[i]]>)
{
ans[++now].chuan=tot[i]; //存答案
ans[now].cs=a[tot[i]];
}
}
if(!now) //没有重复的
{
printf("No duplicates.");
return ;
}
sort(ans+,ans+now+,cmp); //按字典序排列
for(int i=;i<=now;i++)
{
cout<<ans[i].chuan<<' ';
printf("%d\n",ans[i].cs);
}
return ;
}
char数组AC
P2037 电话号码的更多相关文章
- 洛谷P2037 电话号码
P2037 电话号码 题目描述 一串由长长的数字组成的电话号码通常很难记忆.为了方便记忆,有种方法是用单词来方便记忆.例如用“Three Tens”来记忆电话3-10-10-10. 电话号码的标准形式 ...
- [LeetCode] Valid Phone Numbers 验证电话号码
Given a text file file.txt that contains list of phone numbers (one per line), write a one liner bas ...
- [LeetCode] Letter Combinations of a Phone Number 电话号码的字母组合
Given a digit string, return all possible letter combinations that the number could represent. A map ...
- 【代码笔记】iOS-替换电话号码中间4位为-号
一,效果图. 二,代码. RootViewController.m - (void)viewDidLoad { [super viewDidLoad]; // Do any additional se ...
- 国内固定电话正则验证:'tel': [/0\d{2,3}-\d{7,8}(|([-\u8f6c]{1}\d{1,5}))$/, "请填写有效的电话号码"],
// 验证字段 $('#info_form').validator({ rules : { checkMobile : function(ele) { return checkMobile(ele); ...
- C#中使用正则表达式验证电话号码、手机号、身份证号、数字和邮编
验证电话号码的主要代码如下: public bool IsTelephone(string str_telephone) { return System.Text.RegularExpressio ...
- 防止在iOS设备中的Safari将数字识别为电话号码
在测试中发现iPad上的Safari总会把长串数字识别为电话号码,文字变成蓝色,点击还会弹出菜单添加到通讯录. 别的地方倒也罢了,如果在用户名中出现数字(手机注册新浪微博的话用户名就是“手机用户xxx ...
- java 验证手机号码、电话号码(包括最新的电信、联通和移动号码)
一.目前的号码段(2016-12-8更新) 二.代码 package com.test; import java.util.regex.Pattern; public class CheckPho ...
- php电话号码正则表达式常用例子
电话号码正则表达式(支持手机号码,3-4位区号,7-8位直播号码,1-4位分机号) 02 03 ((\d{11})|^((\d{7,8})|(\d{4}|\d{3})-(\d{7,8})|(\d{ ...
随机推荐
- 最全的ADB命令行大全(转)
基本用法 命令语法 adb 命令的基本语法如下: adb [-d|-e|-s ] 如果只有一个设备/模拟器连接时,可以省略掉 [-d|-e|-s ] 这一部分,直接使用 adb . 为命令指定目标设备 ...
- VBA While Wend循环
在While...Wend循环中,如果条件为True,则会执行所有语句,直到遇到Wend关键字. 如果条件为false,则退出循环,然后控件跳转到Wend关键字后面的下一个语句. 语法 以下是VBA中 ...
- JavaScript作用域、作用域链 学习随笔
(本文是这些知识点的自我理解.写之余从头回顾,加深理解.取得更多收获之用.) 作用域(scope) 程序设计概念,通常来说,一段程序代码中所用到的名字(JS叫标识符(如变量名.函数名.属性名.参数.. ...
- 宽字节 多字节 mbstowcs wcstombs
函数 size_t wcstombs(char *dest, const wchar_t *src, size_t n); //wide-character to a multibyte n:被写入到 ...
- ping IP 带时间戳循环显示并写入日志(windos版+linux版)
在工作中,判断网络是否通畅,首选命令就是ping,但有时候我们需要持续ping一个或多个地址时,需要加 -t 即可,但有时候需要在ping的时候加入时间戳并把ping记录写入到日志里面,方法如下: w ...
- RestFramework之解析器
一.什么是解析器? 对请求的数据进行解析 - 请求体进行解析. 解析器在你不拿请求体数据时 不会调用. 安装与使用: https://www.django-rest-framework.org/ 官方 ...
- 在Linux中安装适用于arm64位的nodejs
# 安装适用于arm64位的nodejs runtime v10.16.3 mkdir /runtimes cd /runtimes wget https://nodejs.org/dist/v10. ...
- CMake---基础练习1
因为卡在一个问题上,几经排除应该可能是CMakeLists.txt写的不正确,但是又生成了可执行文件,运行可执行文件报错.多方排除,应该是CMakeLists.txt加载动态库的时候,函数加载的不全. ...
- ES6 解构赋值详解
解构赋值是对赋值运算符的扩展,可以将属性/值从对象/数组中取出,赋值给其他变量. 一.数组的解构赋值 1.基本用法 只要等号两边的模式相同,左边的变量就会被赋予对应的值. let [a, [[b], ...
- linux网络编程之system v消息队列(一)
经过上次对于进程通讯的一些理论的认识之后,接下来会通过实验来进一步加深对进程通讯的认识,话不多说,进入正题: 其实还可以通过管道,但是,管道是基于字节流的,所以通常会将它称为流管道,数据与数据之间是没 ...