使用字典和列表的依赖图
本文关键字:依赖图 列表 字典 | 更新日期: 2023-09-27 18:06:40
我正在制作一个依赖关系图,我在正确添加我的依赖关系和依赖关系时遇到了麻烦。
设置如下:
private List<Tuple<string, string>> DG;
private Dictionary<string, List<string>> dependants;
private Dictionary<string, List<string>> dependees;
我试着添加到我的字典中,比如:
for (int i = 0; i < DG.Count; i++)
{
dependants.Add(DG[i].Item1, new List<string>().Add(DG[i].Item2);
}
它给了我错误"Argument2:不能从void转换为System.Collections.Generic。列表"我试图添加到第二个参数的新列表。我想我知道为什么会出现错误,但是我很难想出另一种正确添加到字典中的方法。
我的目标是这样的:
//DG = {("a", "b"), ("a", "c"), ("b", "d"), ("d", "d")}
// dependents("a") = {"b", "c"}
// dependents("b") = {"d"}
// dependents("c") = {}
// dependents("d") = {"d"}
// dependees("a") = {}
// dependees("b") = {"a"}
// dependees("c") = {"a"}
// dependees("d") = {"b", "d"}
所以("a", "b")意味着"b"依赖于"a"而"a"依赖于"b"
它比你的代码长一点,但这可能是你需要的:
for (int i = 0; i < DG.Count; i++)
{
if (!dependants.ContainsKey(DG[i].Item1))
{
List<string> temp = new List<string>();
temp.add(DG[i].Item2);
dependants.Add(DG[i].Item1, temp);
}
else
dependants[DG[i].Item1].Add(DG[i].Item2);
}
希望较长的代码可以帮助您理解流程。这只是为了创建依赖项。此外,您在原始代码中缺少一个括号关闭:
dependants.Add(DG[i].Item1, new List<string>().Add(DG[i].Item2);
应该dependants.Add(DG[i].Item1, new List<string>().Add(DG[i].Item2));