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