编程题:电话号码

📑打牌 : da pai ge的个人主页

🌤️个人专栏 : da pai ge的博客专栏

☁️宝剑锋从磨砺出,梅花香自苦寒来

📑题目解析

这个题目比较简单 . 借助 hash 表完成字母和数字之间的转换即可 . 注意大小写的情况

🌤️解题思路

  1. 先用 hash 表存储字母和数字之间的映射关系
  2. 每次读到一个字符 , 去 hash 表中查找 , 并进行处理即可 .

☁️代码解析

复制代码
import java.util.*;
import java.io.*;
public class Main
{
public static void main(String[] args) throws Exception
{
//建立映射
//字母--->数字
HashMap<Character, Character> mp = new HashMap<>();
String alpha = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
String num = "22233344455566677778889999";
char[] alphaArr = alpha.toCharArray();
char[] numArr = num.toCharArray();
for(int i = 0; i < alphaArr.length; ++i)
{
mp.put(alphaArr[i], numArr[i]);
}
//用set保存结果,去重
TreeSet<String> set = new TreeSet<>();
String line;
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
while((line = reader.readLine()) != null)
{
set.clear();

int n = Integer.parseInt(line);
//处理n个字符串
for(int i = 0; i < n; ++i)
{
line = reader.readLine();
//保存转换之后的字符串
StringBuilder sb = new StringBuilder();
char[] arr = line.toCharArray();
//处理每一个字符
for(char ch : arr)
{
if(isDigit(ch))
sb.append(ch);
else if(isUpper(ch))
sb.append(mp.get(ch));
}
//调整格式:xxx-xxxx
line = sb.substring(0, 3) + "-" + sb.substring(3);
//保存结果
set.add(line);
}
//打印转换之后的结果
for(String str : set)
System.out.println(str);
//每组数据用空行隔开
System.out.println();
}
}
public static boolean isDigit(char ch)
{
return '0' <= ch && ch <= '9';
}
public static boolean isUpper(char ch)
{
return 'A' <= ch && ch <= 'Z';
}
相关推荐
秋风战士8 分钟前
通信算法之255:无人机频谱探测设备技术详解
算法·无人机
laimaxgg1 小时前
数据结构B树的实现
开发语言·数据结构·c++·b树·算法
mit6.8241 小时前
[Lc6_记忆化搜索] 最长递增子序列 | 矩阵中的最长递增路径
c++·算法·leetcode
ylfhpy3 小时前
Java面试黄金宝典30
java·数据库·算法·面试·职场和发展
明.2443 小时前
DFS 洛谷P1123 取数游戏
算法·深度优先
简简单单做算法5 小时前
基于mediapipe深度学习和限定半径最近邻分类树算法的人体摔倒检测系统python源码
人工智能·python·深度学习·算法·分类·mediapipe·限定半径最近邻分类树
Tisfy6 小时前
LeetCode 2360.图中的最长环:一步一打卡(不撞南墙不回头) - 通过故事讲道理
算法·leetcode··题解
LuckyAnJo6 小时前
Leetcode-100 链表常见操作
算法·leetcode·链表
双叶8367 小时前
(C语言)虚数运算(结构体教程)(指针解法)(C语言教程)
c语言·开发语言·数据结构·c++·算法·microsoft
工一木子7 小时前
大厂算法面试 7 天冲刺:第5天- 递归与动态规划深度解析 - 高频面试算法 & Java 实战
算法·面试·动态规划