C#中判斷一個集合是否是另一個集合的子集的簡單方法
看到這個標題,我們首先想到的是循環(huán)遍歷其中一個數(shù)組,判斷數(shù)組中的每個元素是否都在另一個數(shù)組中出現(xiàn)了,以此來判斷該數(shù)組是不是另一個數(shù)組的子集,但是這樣做就太過復雜了,有沒有簡單一點的方法呢?
打個比方,有這樣的兩個集合:
string[] smallArr = new string[] { "a", "b"};
現(xiàn)在需要判斷smallArr是否是bigArr的子集。只要拿著bigArr和smallArr比較,求差集,如果差集的個數(shù)大于0,就說明smallArr是bigArr的子集。
var exceptArr = bigArr.Except(smallArr);
//判斷是否是子集
if(exceptArr.Any())
{
Console.WriteLine("samllArr 是 bigArr的一個子集");
}
else
{
Console.WriteLine("samllArr 不是 bigArr的一個子集");
}
以上的方式,只能判斷是否是子集,即是子集的那個集合元素永遠小于大的那個集合。
有時候,還存在這樣的需求:判斷bigArr是否包含smallArr,即smallArr可以是bigArr的子集,也可以和bigArr是一樣的。
if(smallArr.All(t => bigArr.Any(b => b==t)))
{
Console.WriteLine("samllArr 是 bigArr的一個子集或一樣");
}
else
{
Console.WriteLine("samllArr 不是 bigArr的一個子集或一樣");
}
相關(guān)文章
C#利用WMI操作DNS服務器(可遠程操作,需要相應權(quán)限)
C#利用WMI操作DNS服務器(可遠程操作,需要相應權(quán)限)...2007-03-03winform下實現(xiàn)win7 Aero磨砂效果實現(xiàn)代碼
winform下實現(xiàn)win7 Aero磨砂效果實現(xiàn)代碼,需要的朋友可以參考下2012-03-03