Run Code
|
API
|
Code Wall
|
Misc
|
Feedback
|
Login
|
Theme
|
Privacy
|
Patreon
Mapas - convertir número telefónico
/*Escribir una función que reciba un número de teléfono conteniendo letras (string) y lo retorne con sus equivalentes en números. El parámetro sólo puede contener números, letras mayúsculas, '-' y paréntesis.*/ #include <iostream> #include <string> #include <set> #include <map> using namespace std; string letrasANum(string telefono) { map<char, string> equivalencias={ {'2',"ABC"}, {'3',"DEF"}, {'4',"GHI"}, {'5',"JKL"}, {'6',"MNO"}, {'7',"PQRS"}, {'8',"TUV"}, {'9',"WXYZ"} }; set<char> no_convertir={'0','1','2','3','4','5','6','7','8','9','(',')','-'}; string resultado=""; for (int i=0; i<telefono.length(); i++) if (no_convertir.find(telefono[i]) != end(no_convertir)) resultado += telefono[i]; else for (auto par : equivalencias) if (par.second.find(telefono[i]) != string::npos){ resultado += par.first; break; } return resultado; } int main() { cout << letrasANum("123-647-EYES") << endl; cout << letrasANum("(325)444-TEST") << endl; cout << letrasANum("653-TRY-THIS") << endl; cout << letrasANum("435-224-7613") << endl; cout << letrasANum("(33D)ONT-FAIL") << endl; cout << letrasANum("(025)445-6741") << endl; }
run
|
edit
|
history
|
help
0
temp_new
CIDP2k19
Test
Prosta implementacja algorytmu Euklidesa (NWD)
Test
ExceptionHandling2
Sequence point and array
Zadanie Kalkulator z bajerami
Stock buy/sell
Segmented Sieve