[英]Using Dictionary to map byte to BitArray
我正在开发实现简单替换密码的应用程序。 现在出于速度原因(并且这是其中的条件之一),我需要使用BitArray进行加密和解密。 用户将输入“编码”字母,而我需要以某种方式进行映射,因此我选择了Dictionary,因为它使用哈希表并且在用户访问数据时具有O(1)复杂性。 但是现在我发现自己想知道当我像这样初始化“编码”字母时该怎么做:
BitArray codedAlphabet = new BitArray(bytes);
这将使我使用2 for循环来实现我的目标。 有人有不同的想法吗? 希望您理解我正在努力实现的目标。 先感谢您。
码:
namespace Harpokrat.EncryptionAlgorithms
{
// Simple substitution cypher algorithm
public class SimpleSubstitutionStrategy : IEncryptionStrategy
{
private string alphabet; // message to be encrypted
private string coded; // this will be the key (input from file or from UI)
private ArrayList AlphabetBackUp = new ArrayList();
private ArrayList CodedBackUp = new ArrayList();
#region Properties
public string Alphabet
{
get
{
return this.alphabet;
}
set
{
this.alphabet = value;
foreach (char c in this.alphabet.ToCharArray())
{
this.AlphabetBackUp.Add(c);
}
}
}
public string Coded
{
get
{
return this.coded;
}
set
{
this.coded = "yqmnnsgwatkgetwtawuiqwemsg"; //for testing purposes
foreach (char c in this.coded.ToCharArray())
{
this.CodedBackUp.Add(c);
}
}
}
#endregion
public string Decrypt(string message)
{
message = message.ToLower();
string result = "";
for (int i = 0; i < message.Length; i++)
{
int indexOfSourceChar = CodedBackUp.IndexOf(message[i]);
if (indexOfSourceChar < 0 || (indexOfSourceChar > alphabet.Length - 1))
{
result += "#";
}
else
{
result += alphabet[indexOfSourceChar].ToString();
}
}
return result;
}
public string Encrypt(string message)
{
message = message.ToLower();
string result = "";
for(int i = 0; i < message.Length; i++)
{
int indexOfSourceChar = AlphabetBackUp.IndexOf(message[i]);
if (indexOfSourceChar < 0 || (indexOfSourceChar > coded.Length - 1))
{
result += "#";
}
else
{
result += coded[indexOfSourceChar].ToString();
}
}
return result;
}
}
}
我建议同时使用一种方法来设置alphabet
和coded
,该方法在内部构建您需要执行加密和解密操作的两个字典,以及一种用于执行get-or-return-default('# (以您的情况为准)。 这样,您可以实现一个函数,该函数根据传入的字典进行加密或解密(如果您愿意使用LINQ,可以在一行代码中实现)。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.