国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C# > 正文

c# list部分操作實現(xiàn)代碼

2020-01-24 03:08:57
字體:
供稿:網(wǎng)友

C# Linq獲取兩個List或數(shù)組的差集交集

復(fù)制代碼 代碼如下:

List<int> list1 = newList<int>();
list1.Add(1);
list1.Add(2);
list1.Add(3);
List<int> list2 = newList<int>();
list2.Add(3);
list2.Add(4);
list2.Add(5);
//得到的結(jié)果是4,5 即減去了相同的元素。
List<int> list3 = list2.Except(list1).ToList();
foreach(inti inlist3)
{
MessageBox.Show(i.ToString());
}

合并兩個數(shù)組,并去掉重復(fù)元素,然后排序(C#)

復(fù)制代碼 代碼如下:

List<int> numbers1 = newList<int>() { 5, 4, 1, 3, 9, 8, 6, 7, 12, 10};
List<int> numbers2 = newList<int>() { 15, 14, 11, 13, 19, 18, 16, 17, 12, 10};
varnewQuerty = numbers1.Concat(
fromn innumbers2
where!numbers1.Contains(n)
selectn
).OrderBy(n=>n);

合并兩個數(shù)組,并去除合并后的重復(fù)數(shù)據(jù), 并排序

復(fù)制代碼 代碼如下:

int[] A={1,2,2,3,4,5,6,6,6};
int[] B={2,2,2,3,7,8,9,5};

List<int> list = new List<int>(A);
list.AddRange(B);

list.Sort();

//去除重復(fù)項
foreach (int i in list.Distinct<int>())
{
Console.WriteLine(i);
}

C# 取兩個數(shù)組的相同元素
以往我們都是肯定絞盡腦汁,肯定什么循環(huán),元素大小,什么因素都考慮進去。但是現(xiàn)在采用Linq可以很好的解決這個問題。找出兩個或多個數(shù)組的相同項。

代碼相當(dāng)簡單:

復(fù)制代碼 代碼如下:

usingSystem;
usingSystem.Collections.Generic;
usingSystem.Linq;
usingSystem.Text;
namespaceTest4_03
{
classProgram
{
staticvoidMain(string[] args)
{
string[] names = {"Adams","Arthur","Buchanan","Tsbuchis","ShCian","FuchsiaLinda","DecheChen","Lotheer","FindLanciCade","SorchLand","JiangZheng","MisiiLoda","Gtod","Dfac","Lama","BakCades","Losangle","ZheWQ","GehengDahaLothi","ToryLandey","DakaLothy","BthLanda","MenNorth","Fith","FoxMain","DontM","Saobba","Del","Sala","Ghero","BhthLaPhda"};
IEnumerable<string> skip = names.Skip(10);
IEnumerable<string> take = names.Take(11);
//取出兩個序列中交集部分,按理論應(yīng)該輸出JiangZheng
IEnumerable<string> intersect = skip.Intersect(take);
foreach(varsinintersect)
{
Console.WriteLine(s);
}
Console.ReadKey();
}
}
}

C# 獲取兩個數(shù)組集合的差集,交集
今天在做一個樹形選擇節(jié)點時,遇到一個問題,屬性節(jié)點是記錄了相關(guān)的ID值,第一次呢全部對這些ID進行處理,但是接下來再次選擇就要分情況了,原先選擇的ID如果不在新選擇的集合中那么剔除掉,否則,原先ID不傳入函數(shù)處理,新ID傳入函數(shù)處理:

比如原來
①選擇的ID是:1,2,3,4 下次:1,2,3,4,5, 那么這時候5要處理,1,2,3,4維持原樣。
②選擇ID是:1,3 下次: 3,4,5 那么這時候4,5 要處理,3 維持原樣。1剔除。
③選擇ID是:1,2,3,4,5 下次:3,4,5 那么這時候3,4,5都維持原樣,1,2剔除。
④選擇ID是:1,2 下次:3,4,5 那么這時候3,4,5處理,1,2剔除。

簡化一下數(shù)學(xué)模型:

大家發(fā)現(xiàn)沒其實這就是一個數(shù)學(xué)的概念,集合的差集,那么我們怎么處理呢? 假設(shè)前次選擇的集合為A,后次選擇為B

得到要處理的很簡單:B-A (B與A的差集)就是要處理的集合元素,為什么呢?根據(jù)概念可知哈!

那么得到不做處理的怎么辦呢? 不要處理的必然是B的子集,那么怎么得到呢?

出來啦既是:B-(B-A) 這是為什么呢? B-A 就是要處理的,而維持原樣的就是當(dāng)然就是:B-(B-A),

那么剔除的集合呢? A-(B-(B-A))

如何用C#表示呢,我這里就不用什么循環(huán)之類的了,我用的是NET3.5 那就好辦了,用Linq處理:

俺這里特殊點,右鍵得到的樹形集合(lstSource)包含了其他信息,先獲取ID集合再說:

復(fù)制代碼 代碼如下:

var m_ilAllSelect = lstSource.Select(r => r.ID).AsEnumerable();//新選擇的列表

///////下面開始處理了

List<int> m_ilNewSelect = m_ilAllSelect.ToList();//新選擇列表
List<int> m_ilExcept = m_ilNewSelect.Except(m_mcuids).ToList(); //兩者的不同之處
List<int> m_iExceptAfterAndNew = m_ilNewSelect.Except(m_ilExcept).ToList();//新選擇列表與差集比較,則是新選擇中的舊的

為了簡化給大家,這里的A代表舊集合,B代表新集合,這里的集合都是List<int>泛型列表。
那么要處理的就是 B.Except(A), 維持原樣的:B( B.Except(A)), 剔除的:A.Except(B( B.Except(A))),
不要問我這個Except方法啥意思?看MSDN吧,google也行啦!
當(dāng)然我實際的源碼比這更細(xì)致點,至此解決集合的差集的知識點就這些了

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 元朗区| 冕宁县| 华亭县| 台中市| 六盘水市| 根河市| 桑植县| 威宁| 仁寿县| 大化| 衡东县| 淳化县| 银川市| 乌兰浩特市| 临夏市| 长寿区| 平顺县| 开平市| 土默特右旗| 健康| 姚安县| 榆树市| 邹平县| 汉沽区| 兰溪市| 四会市| 巴塘县| 大理市| 监利县| 枣阳市| 德安县| 石渠县| 许昌市| 霍邱县| 轮台县| 岱山县| 社旗县| 肥西县| 怀宁县| 宁国市| 许昌县|