Welcome

首页 / 软件开发 / 数据结构与算法 / UVa 10921 Find the Telephone (water ver.)

UVa 10921 Find the Telephone (water ver.)2014-10-02 synapse7

10921 - Find the Telephone

Time limit: 3.000 seconds

http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=24&page=show_problem&problem=1862

In some places is common to remember a phone number associating its digits to letters. In this way the expression MY LOVE means 69 5683. Of course there are some problems, because some phone numbers can not form a word or a phrase and the digits 1 and 0 are not associated to any letter.

Your task is to read an expression and find the corresponding phone number based on the table below. An expression is composed by the capital letters (A-Z), hyphens (-) and the numbers 1 and 0.

LettersNumber
ABC2
DEF3
GHI4
JKL5
MNO6
PQRS7
TUV8
WXYZ9

Input

The input consists of a set of expressions. Each expression is in a line by itself and has C characters, where 1 ≤ C ≤ 30. The input is terminated by enf of file (EOF).

Output

本文URL地址:http://www.bianceng.cn/Programming/sjjg/201410/45354.htm

For each expression you should print the corresponding phone number.

Sample Input

1-HOME-SWEET-HOMEMY-MISERABLE-JOB

Sample Output

1-4663-79338-466369-647372253-562
完整代码:

/*0.018s*/#include<cstdio>#include<cctype>#include<cstring>const char num[] = {" 22233344455566677778889999"};char str[35];int main(){int len, i;while (gets(str)){len = strlen(str);for (i = 0; i < len; ++i)putchar(isalpha(str[i]) ? num[str[i] & 31] : str[i]);putchar(10);}return 0;}