摩斯密码(Morse code) C#实现
摩斯密码是一种经典的信号编码方式,通过点(.)和划(-)的不同组合来表示字母、数字和标点符号。尽管现代通信技术已经非常发达,摩斯密码在应急通信、业余无线电和编程教学等领域仍然具有重要价值。本文将详细介绍如何使用C#语言实现摩斯密码的编码与解码功能。
摩斯密码编码规则
摩斯密码使用统一的编码表,其中每个字符对应一组由点和划组成的序列。以下是国际摩斯密码标准编码表的核心部分:
字母A-Z:A是 .- ,B是 -... ,C是 -.-. 等
数字0-9:0是 ----- ,1是 .---- ,2是 ..--- 等
常见标点:句号 .-.-.- ,逗号 --..-- ,问号 ..--.. 等
字符之间用空格分隔,单词之间用斜杠 / 或更长的停顿表示。
C#实现方案设计
我们将设计一个名为 MorseCodeConverter 的静态类,包含以下核心功能:
编码方法:将普通文本转换为摩斯密码
解码方法:将摩斯密码还原为普通文本
字典存储:使用
Dictionary<string, string>存储编码映射关系
为了提高效率,编码和解码分别使用正向字典和反向字典。
核心代码实现
1. 定义编码字典
首先创建编码映射表,包含所有需要的字符:
using System;
using System.Collections.Generic;
using System.Text;
using System.Text.RegularExpressions;
public static class MorseCodeConverter
{
private static readonly Dictionary<string, string> encodeDict = new Dictionary<string, string>
{
{"A", ".-"}, {"B", "-..."}, {"C", "-.-."}, {"D", "-.."},
{"E", "."}, {"F", "..-."}, {"G", "--."}, {"H", "...."},
{"I", ".."}, {"J", ".---"}, {"K", "-.-"}, {"L", ".-.."},
{"M", "--"}, {"N", "-."}, {"O", "---"}, {"P", ".--."},
{"Q", "--.-"}, {"R", ".-."}, {"S", "..."}, {"T", "-"},
{"U", "..-"}, {"V", "...-"}, {"W", ".--"}, {"X", "-..-"},
{"Y", "-.--"}, {"Z", "--.."},
{"0", "-----"}, {"1", ".----"}, {"2", "..---"}, {"3", "...--"},
{"4", "....-"}, {"5", "....."}, {"6", "-...."}, {"7", "--..."},
{"8", "---.."}, {"9", "----."},
{".", ".-.-.-"}, {",", "--..--"}, {"?", "..--.."}, {"!", "-.-.--"},
{"/", "-..-."}, {"(", "-.--."}, {")", "-.--.-"}, {"&", ".-..."},
{":", "---..."}, {";", "-.-.-."}, {"=", "-...-"}, {"+", ".-.-."},
{"-", "-....-"}, {"_", "..--.-"}, {""", ".-..-."}, {"@", ".--.-."},
{" ", "/"}
};
// 解码时使用的反向字典
private static readonly Dictionary<string, string> decodeDict;
static MorseCodeConverter()
{
decodeDict = new Dictionary<string, string>();
foreach (var kvp in encodeDict)
{
// 空格在解码时特殊处理,不加入反向字典
if (kvp.Key != " ")
{
decodeDict[kvp.Value] = kvp.Key;
}
}
}
}2. 编码方法实现
编码方法接受普通文本字符串,将其转换为摩斯密码。处理逻辑包括:
将输入文本转换为大写
遍历每个字符,查找编码字典
字符之间用空格分隔,单词之间保留斜杠
public static string Encode(string plainText)
{
if (string.IsNullOrEmpty(plainText))
{
return string.Empty;
}
plainText = plainText.ToUpperInvariant();
var result = new StringBuilder();
foreach (char c in plainText)
{
string key = c.ToString();
if (encodeDict.ContainsKey(key))
{
if (result.Length > 0)
{
// 单词之间用斜杠表示,字符之间用空格
if (key == " ")
{
result.Append(" / ");
}
else
{
result.Append(' ');
}
}
else if (key == " ")
{
continue;
}
if (key != " ")
{
result.Append(encodeDict[key]);
}
}
else
{
// 遇到无法编码的字符,可以选择忽略或抛出异常
// 这里选择忽略
continue;
}
}
return result.ToString();
}3. 解码方法实现
解码方法将摩斯密码还原为可读文本。需要注意处理单词分隔符(斜杠)以及多个空格的情况:
public static string Decode(string morseCode)
{
if (string.IsNullOrEmpty(morseCode))
{
return string.Empty;
}
// 使用正则表达式分割:空格分隔字符,斜杠分隔单词
// 先将连续的多个空格标准化
morseCode = Regex.Replace(morseCode.Trim(), @"s+", " ");
var result = new StringBuilder();
string[] words = morseCode.Split('/');
for (int w = 0; w < words.Length; w++)
{
string word = words[w].Trim();
if (string.IsNullOrEmpty(word))
{
continue;
}
string[] symbols = word.Split(' ');
foreach (string symbol in symbols)
{
if (string.IsNullOrEmpty(symbol))
{
continue;
}
if (decodeDict.ContainsKey(symbol))
{
result.Append(decodeDict[symbol]);
}
else
{
// 遇到无法解码的符号,可以添加占位符
result.Append('?');
}
}
if (w < words.Length - 1)
{
result.Append(' ');
}
}
return result.ToString();
}完整示例与测试
以下是一个完整的控制台应用程序示例,演示如何使用上述编码和解码功能:
class Program
{
static void Main(string[] args)
{
string originalText = "Hello World 123";
Console.WriteLine("原始文本: " + originalText);
string encoded = MorseCodeConverter.Encode(originalText);
Console.WriteLine("摩斯密码: " + encoded);
string decoded = MorseCodeConverter.Decode(encoded);
Console.WriteLine("解码结果: " + decoded);
// 测试带有标点的文本
string test2 = "What is your name?";
Console.WriteLine("n原始文本: " + test2);
string enc2 = MorseCodeConverter.Encode(test2);
Console.WriteLine("摩斯密码: " + enc2);
string dec2 = MorseCodeConverter.Decode(enc2);
Console.WriteLine("解码结果: " + dec2);
Console.WriteLine("n测试完成。");
Console.ReadKey();
}
}预期输出结果:
原始文本: Hello World 123 摩斯密码: .... . .-.. .-.. --- / .-- --- .-. .-.. -.. / .---- ..--- ...-- 解码结果: HELLO WORLD 123 原始文本: What is your name? 摩斯密码: .-- .... .- - / .. ... / -.-- --- ..- .-. / -. .- -- . ..--.. 解码结果: WHAT IS YOUR NAME?
高级功能扩展
以上基础实现可以进一步扩展,增加更多实用功能:
1. 添加自定义字符支持
允许用户动态注册新的编码映射:
public static void AddCustomMapping(string character, string morse)
{
if (string.IsNullOrEmpty(character) || string.IsNullOrEmpty(morse))
{
return;
}
string key = character.ToUpperInvariant();
if (!encodeDict.ContainsKey(key))
{
encodeDict[key] = morse;
if (key != " ")
{
decodeDict[morse] = key;
}
}
}2. 文件批量转换
可以编写方法从文本文件读取内容并进行批量编码或解码:
public static void EncodeFile(string inputFilePath, string outputFilePath)
{
string content = System.IO.File.ReadAllText(inputFilePath);
string encoded = Encode(content);
System.IO.File.WriteAllText(outputFilePath, encoded);
}
public static void DecodeFile(string inputFilePath, string outputFilePath)
{
string content = System.IO.File.ReadAllText(inputFilePath);
string decoded = Decode(content);
System.IO.File.WriteAllText(outputFilePath, decoded);
}性能与可靠性考虑
在实际使用中,需要注意以下几点:
输入验证:对输入字符串进行空值检查和合法性校验
大小写处理:将输入统一转为大写,避免编码遗漏
异常符号处理:对无法编码或解码的符号采取合理的处理策略(忽略、替换为问号或抛出异常)
分隔符标准化:解码时先对输入的摩斯密码进行空格标准化,提高容错性
总结
本文介绍了使用C#实现摩斯密码编码与解码的完整方法。通过构建双向字典映射,可以高效地在普通文本和摩斯密码之间进行转换。该实现具有良好的可扩展性,支持自定义字符映射,并且可以轻松集成到更复杂的应用程序中。摩斯密码虽然是一种古老的编码方式,但它在编程练习、算法学习和特殊通信场景中仍然具有现实意义。