繁体   English   中英

使用什么样的数据结构?

[英]What kind of data structure to use?

我正在开展一个需要跟踪的项目:

  • 5-6只是字符串名称的根项
  • 每个根项都需要具有不同标识符类型的多个子项(int,string,float等)。 一个根的所有子节点都是相同类型,但每个根节点将具有不同的子类型
  • 用户需要能够从每个根添加/删除子项
  • 我稍后需要单独访问每个孩子,并在需要时执行字符串操作和解析

我想过可能会使用一个字典,其中Key是一个字符串,而Values是对象列表。 或者为每个根项创建一个唯一的类,每个类将包含一个子列表。

有没有人有什么好建议? 我对OOP还很新,请耐心等我:)

谢谢!

public interface IRoot {}

public class RootItem<T> : IRoot
{
    public string Name { get; set; }
    public List<T> Children {get; set; }
}

然后保持一个Dictionary<string, IRoot>来保存它们。

Dictionary<string, IRoot> hair = new Dictionary<string, IRoot>();
hair.Add(
  new RootItem<int>()
      {
        Name = "None",
        Children = new List<int>() {1, 2, 3, 4}
      }
);

hair.Add(
  new RootItem<decimal>()
      {
        Name = "None",
        Children = new List<decimal>() {1m, 2m, 3m, 4m}
      }
);

如何使用List<T>包含子类的泛型类:

public class Root<T>
{
    private List<T> children = null;

    public Root(string name)
    {
        Name = name;
    }

    public string Name { get; set; }

    public List<T> Children
    {
        get
        {
            if (children == null)
            {
                children = new List<T>();
            }

            return children;
        }
    }
}

Root<int> intRoot = new Root<int>("IntRoot");
intRoot.Children.Add(23);
intRoot.Children.Add(42);

Root<string> stringRoot = new Root<string>("StringRoot");
stringRoot.Children.Add("String1");
stringRoot.Children.Add("String2");
stringRoot.Children.Add("String3");
stringRoot.Children.Add("String4");

如果你想在一个对象中保存所有的根,你可以编写自己的类或使用一个Tuple

var rootGroup = Tuple.Create(intRoot, stringRoot);
// intRoot is accessible as rootGroup.Item1
// stringRoot is accessible as rootGroup.Item2

听起来像Dictionary<string, Tuple<type1, type 2, etc>>是一个很好的候选者。

键是字符串(root)。 根的孩子是元组。 我们可以添加项目到元组。 感谢您指出了这一点。

元组的好起点

这是一种方法。 需要进行大量的投射,但它完成了工作:

    static void Main(string[] args)
    {
        Dictionary<string, IRootCollection> values = new Dictionary<string, IRootCollection>();

        values["strings"] = new RootCollection<string>();
        (values["strings"] as RootCollection<string>).Add("foo");
        (values["strings"] as RootCollection<string>).Add("bar");

        values["ints"] = new RootCollection<int>();
        (values["ints"] as RootCollection<int>).Add(45);
        (values["ints"] as RootCollection<int>).Add(86);
    }

    interface IRootCollection { }
    class RootCollection<T> : List<T>, IRootCollection { }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM