C# 合併只要有交集的所有集合

来源:https://www.cnblogs.com/Iconnector/archive/2019/01/25/10320579.html
-Advertisement-
Play Games

1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Text; 5 using System.Threading.Tasks; 6 7 namespace ConsoleApp ...


  1 using System;
  2 using System.Collections.Generic;
  3 using System.Linq;
  4 using System.Text;
  5 using System.Threading.Tasks;
  6 
  7 namespace ConsoleApplication2
  8 {
  9     class Program
 10     {
 11         static void Main(string[] args)
 12         {
 13 
 14             List<int> list1 = new List<int> { 1, 2, 3 };
 15             List<int> list2 = new List<int> { 4, 5, 6 };
 16             List<int> list3 = new List<int> { 1, 4, 7 };
 17 
 18 
 19             List<int> list4 = new List<int> { 10, 11, 12 };
 20             List<int> list5 = new List<int> { 13, 11, 14 };
 21 
 22 
 23             List<int> list6 = new List<int> { 16, 17, 18 };
 24             List<int> list7 = new List<int> { 18, 19, 20 };
 25 
 26             List<List<int>> list = new List<List<int>>();
 27             list.Add(list1);
 28             list.Add(list2);
 29             list.Add(list3);
 30             list.Add(list4);
 31             list.Add(list5);
 32             list.Add(list6);
 33             list.Add(list7);
 34 
 35             List<int> allint = new List<int>();//所有的集合數據
 36             HashSet<int> repeated = new HashSet<int>(); //得到沒有重覆的hashset
 37             foreach (List<int> item in list)
 38             {
 39                 foreach (int index in item)
 40                 {
 41                     if (allint.Contains(index))
 42                         repeated.Add(index);//得到所有重覆的集合的元素
 43                     allint.Add(index);//得到所有的集合的元素
 44                 }
 45             }
 46 
 47 
 48             foreach (var setkey in repeated)//迴圈重覆的值
 49             {
 50                 List<int> templist = null;//臨時
 51                 List<List<int>> removelist = new List<List<int>>();
 52                 foreach (var item in list)//迴圈
 53                 {
 54                     //if (templist == null)
 55                     //{
 56                     //    templist = item;
 57                     //    removelist.Add(item);
 58                     //}
 59 
 60                     //if (item.Contains(setkey))
 61                     //{
 62                     //    removelist.Add(item);
 63                     //    templist = templist.Union(item).ToList();
 64                     //}
 65 
 66                     if (item.Contains(setkey))
 67                     {
 68                         if (templist == null)
 69                         {
 70                             templist = item;
 71                             removelist.Add(item);
 72                         }
 73                         else
 74                         {
 75                             removelist.Add(item);
 76                             templist = templist.Union(item).ToList();
 77                         }
 78                     }
 79                 }
 80                 foreach (var item in removelist)
 81                 {
 82                     list.Remove(item);
 83                 }
 84                 removelist.Clear();
 85                 list.Add(templist);
 86             }
 87 
 88             foreach (var item in list)
 89             {
 90                 foreach (var item1 in item)
 91                 {
 92                     Console.Write(item1 + " , ");
 93                 }
 94                 Console.Write("\r\n");
 95             }
 96             Console.ReadKey();
 97         }
 98 
 99 
100     }
101 }


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 【題目背景】 在成功地發明瞭魔方之後,魯比克先生髮明瞭它的二維版本,稱作魔板。這是一張有8個大小相同的格子的魔板: 【題目描述】 我們知道魔板的每一個方格都有一種顏色。這8種顏色用前8個正整數來表示。可以用顏色的序列來表示一種魔板狀態,規定從魔板的左上角開始,沿順時針方向依次取出整數,構成一個顏色序 ...
  • 以前寫過介紹HashMap的文章,文中提到過HashMap在put的時候,插入的元素超過了容量(由負載因數決定)的範圍就會觸發擴容操作,就是rehash,這個會重新將原數組的內容重新hash到新的擴容數組中,在多線程的環境下,存在同時其他的元素也在進行put操作,如果hash值相同,可能出現同時在同 ...
  • 此代碼是上一期的改版 需要用到的Python庫有 1.pygame 2.time 3.xmusic(我自己寫的用來做音樂索引) 4.colorama(美觀) 推薦使用pip安裝 方法: pip install 庫 導入步驟: 1.下載xmusic(點擊藍色字體下載) 2.把下載好的文件放到Pytho ...
  • Spring Boot 編寫自己的"過濾器" 又好久沒有寫博客進行總結了,說實話,就是 "懶",懶得總結,懶得動.之所以寫這篇博客,是因為最近對接公司SSO服務的時候,需要自定義攔截器,spring mvc 中xml的配置文章可以在網上找到很多,但是由於我用的是 Spring boot ,你也知道, ...
  • 答案:是線程安全的,只讀不寫多線程下,完全不需要加鎖! 測試代碼: 模擬5萬個線程讀字典,看看是否混亂: 完全不需要擔心,放心 ...
  • 從頭認識一下docker-附帶asp.net core程式的docker化部署 ...
  • 第1篇:https://www.cnblogs.com/cgzl/p/10294175.html 第2篇 String:https://www.cnblogs.com/cgzl/p/10297565.html 第3篇 Hash:https://www.cnblogs.com/cgzl/p/10301 ...
  • 諸暨牌頭鎮山下周村壽連軍 2016年2月1日 諸暨牌頭鎮山下周村村支書壽連軍伙同江蘇海安人史發龍在根本沒有承包到諸暨凱信大廈工程的事實情況下,利用工程分包合同騙取我本人吳善如工程保證金150萬元! 江蘇海安市公安局已經將壽連軍 史發龍 以及其子壽鵬飛立案為合同詐騙案! 經過百度搜索查詢 壽連軍以及其 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...