c# - C# 严格检查一个字符串中的所有字符是否存在于另一个字符串中(无 LINQ)
问题描述
我有一本字典,我想删除以某种方式包含给定单词的所有字符的所有键。例如,如果给定的单词已损坏,则应删除所有带有“corrupt”、“co2rrupt”、“ruptcor”等键的键/对值。
到目前为止,我有以下代码,但它似乎不起作用,我不知道为什么。
static Dictionary<string,double> Dict2(){
var dict = new Dictionary < string, double > ();
dict.Add("rupt cor0",1);
dict.Add("cor rupt1", 33);
dict.Add(" 4 cor ru pt4", 10752);
dict.Add("ted45", 6.878);
dict.Add("key2", 0.0033482143);
var word = "corrupt";
Console.WriteLine("This is the origina dictionary");
foreach (KeyValuePair<string, double> kvp in dict)
{
Console.WriteLine($"Key {kvp.Key}: Value={kvp.Value}");
}
foreach (KeyValuePair<string, double> entry in dict)
{
foreach (char character in word)
{
if (entry.Key.Contains(character))
{
dict.Remove(entry.Key);
}
}
}
这段代码应该删除前 3 对,但是当我在删除这些对后重新打印字典时,它只包含 key2:0.0033482143。
我想要一种不使用 LINQ 的方法。
解决方案
一种方法是遍历所有键,如果键长度至少与单词一样长,则遍历单词的每个字符并将其从键中删除。那么如果我们删除了所有的字符,那么这个键应该被删除,因为它包含了所有的字符。这需要创建一个临时变量来存储 key 和 word 值,因为我们不想修改原始变量。
var keysToRemove = new List<string>();
foreach (var key in dict.Keys)
{
if (key.Length < word.Length) continue;
var tmpKey = key;
var tmpWord = word;
foreach (var chr in word)
{
var keyIndex = tmpKey.IndexOf(chr);
if (keyIndex < 0) break;
tmpKey = tmpKey.Remove(keyIndex, 1);
tmpWord = tmpWord.Remove(0, 1);
}
if (tmpWord.Length == 0) keysToRemove.Add(key);
}
foreach (var keyToRemove in keysToRemove)
{
dict.Remove(keyToRemove);
}
推荐阅读
- wpf - WPF 添加按钮单击未触发
- android - Firebase - 预定义的用户列表和电话号码身份验证
- python - 矢量微分方程
- facebook-graph-api - 返回评论总数,包括共享位置
- python - 在 Lambda 函数响应中显示 JSON 文件 - AWS
- point-clouds - Agisoft Metashape - 非活动对齐块
- r - ggplot 通过 NA 重新缩放图例(然后回填 NA 值)
- sql - 无效的 NEW 或 OLD 规范 Oracle SQL
- pandas - MongoDB 聚合管道与 Pandas 聚合
- python - Python输出文件的不同日志级别和终端