Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
193 views
in Technique[技术] by (71.8m points)

c# - Filter out path strings beginning with strings

I have a collection of paths (e.g. C:Users, C:Userscheese, D:Shadowstuff ,D:Shadow). Is there any way to get rid of strings that are lesser path? e.g. to only leave C:Userscheese and D:Shadowstuff and make it FAST and memory un-intensive?

It is important that the strings can come in any order.

See Question&Answers more detail:os

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

I would order paths in descending way, and then just skip sub-paths when enumerating collection of paths and adding them to results:

string[] paths = { @"C:Users", @"C:Userscheese", @"D:Shadowstuff", @"D:Shadow" };

string currentPath = "";
List<string> result = new List<string>();
var comparer = StringComparer.InvariantCultureIgnoreCase;

foreach (var path in paths.OrderByDescending(p => p, comparer))
{
    if (currentPath.IndexOf(path, StringComparison.InvariantCultureIgnoreCase) >= 0)
        continue;

    result.Add(path);
    currentPath = path;
}

Result:

[
  "D:\Shadow\stuff",
  "C:\Users\cheese"
]

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...