兩個集合對比

来源:https://www.cnblogs.com/axzxs2001/archive/2019/10/08/11637113.html

在GitHub上有個項目,本來是作為自己研究學習.net core的Demo,沒想到很多同學在看,還給了很多星,所以覺得應該升成3.0,整理一下,寫成博分享給學習.net core的同學們。 項目名稱:Asp.NetCoreExperiment 項目地址:https://github.c... ...


在GitHub上有個項目,本來是作為自己研究學習.net core的Demo,沒想到很多同學在看,還給了很多星,所以覺得應該升成3.0,整理一下,寫成博分享給學習.net core的同學們。

項目名稱:Asp.NetCoreExperiment

項目地址:https://github.com/axzxs2001/Asp.NetCoreExperiment

 

今天先分享幾個對集合知識點。

兩個集合對比代碼:

GitHub代碼庫(https://github.com/axzxs2001/Asp.NetCoreExperiment/tree/master/Asp.NetCoreExperiment/Common/CompareCollections

 1         static void Main(string[] args)
 2         {
 3             var leftKes = new List<string>() { "111111", "222222", "333333", "444444" };
 4             var rightKes = new List<string>() { "333333", "444444", "555555", "666666" };
 5 
 6             Console.WriteLine("Left集合");
 7             Console.WriteLine(string.Join(',', leftKes));
 8             Console.WriteLine("-------------------------------------");
 9 
10             Console.WriteLine("Right集合");
11             Console.WriteLine(string.Join(',', rightKes));
12             Console.WriteLine("-------------------------------------");
13 
14             Console.WriteLine("Left多的 ");
15             Console.WriteLine(string.Join(',', leftKes.Except(rightKes)));
16             Console.WriteLine("-------------------------------------");
17 
18             Console.WriteLine("Right多的 ");
19             Console.WriteLine(string.Join(',', rightKes.Except(leftKes).ToList()));
20             Console.WriteLine("-------------------------------------");
21 
22             Console.WriteLine("Left和Right交集 ");
23             Console.WriteLine(string.Join(',', rightKes.Intersect(leftKes)));
24             Console.WriteLine("-------------------------------------");
25 
26             Console.WriteLine("Left和Right並集 ");
27             Console.WriteLine(string.Join(',', leftKes.Union(rightKes)));
28             Console.WriteLine("-------------------------------------");
29 
30             Console.WriteLine("Left和Right對稱差集 ");
31             Console.WriteLine(string.Join(',', leftKes.Union(rightKes).Except(rightKes.Intersect(leftKes))));
32             Console.WriteLine("-------------------------------------");
33 
34         }

 

運行速度測試代碼:

GitHub代碼庫(https://github.com/axzxs2001/Asp.NetCoreExperiment/tree/master/Asp.NetCoreExperiment/Common/CSharp%E8%8E%B7%E5%8F%96%E4%B8%A4%E4%B8%AA%E9%9B%86%E5%90%88%E4%B8%AD%E7%9B%B8%E5%90%8C%E7%9A%84%E5%92%8C%E4%B8%8D%E5%90%8C%E7%9A%84%E7%BB%93%E6%9E%9C

 1         static void Test()
 2         {
 3             Console.WriteLine("-------------------開始初始化集合-------------------");
 4             #region 製造數據
 5             var watch = new Stopwatch();
 6             watch.Start();
 7             var listA = new List<string>();
 8             var listB = new List<string>();
 9             for (int i = 0; i < 1000000; i++)
10             {
11                 var id = Guid.NewGuid().ToString();
12                 listA.Add(id);
13             }
14             listB.AddRange(listA);
15             //製造B的差異數據
16             for (int i = 0; i < 10; i++)
17             {
18                 var tick = DateTime.Now.Ticks;
19                 var random = new Random((int)(tick & 0xffffffffL) | (int)(tick >> 32));
20                 var index = random.Next(1, 100000);
21                 listB[index] = Guid.NewGuid().ToString();
22             }
23             watch.Stop();
24             TimeSpan span = watch.Elapsed;
25             Console.WriteLine("製造數據總共花費{0}ms.", span.TotalMilliseconds);
26             #endregion
27 
28             #region 比較
29             Console.WriteLine("-------------------開始比較-------------------");
30             Console.WriteLine("-------------------listA中交集外---------------------");
31             watch = new Stopwatch();
32             watch.Start();
33             var listD = listA.Except(listA.Intersect(listB));
34             watch.Stop();
35             span = watch.Elapsed;
36             Console.WriteLine("listA中交集外 總共花費{0}ms.", span.TotalMilliseconds);
37             foreach (var item in listD)
38             {
39                 Console.WriteLine(item);
40             }
41             Console.WriteLine("----------------------listB中交集外--------------------");
42             watch = new Stopwatch();
43             watch.Start();
44             var listE = listB.Except(listA.Intersect(listB));
45             watch.Stop();
46             span = watch.Elapsed;
47             Console.WriteLine("listB中交集外 總共花費{0}ms.", span.TotalMilliseconds);
48             foreach (var item in listE)
49             {
50                 Console.WriteLine(item);
51             }
52             Console.WriteLine("--------------listA和listB中交集外-------------------");
53             watch = new Stopwatch();
54             watch.Start();
55             var listF = listA.Concat(listB).Except(listA.Intersect(listB));
56             watch.Stop();
57             span = watch.Elapsed;
58             Console.WriteLine("listA和listB中交集外 總共花費{0}ms.", span.TotalMilliseconds);
59             foreach (var item in listF)
60             {
61                 Console.WriteLine(item);
62             }
63             #endregion
64         }

對比的運行時長結果:

我的配置是:

 


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

更多相關文章
  • 直接訪問redis的中國官網,在下載部分,可以看到安裝和使用的方式。wget http://download.redis.io/releases/redis-5.0.4.tar.gztar xzf redis-5.0.4.tar.gzcd redis-5.0.4make./src/redis-ser ...
  • xml即可擴展標記語言,它可以用來標記數據、定義數據類型,是一種允許用戶對自己的標記語言進行定義的源語言。 本文主要學習的ElementTree是python的XML處理模塊,它提供了一個輕量級的對象模型。在使用ElementTree模塊時,需要import xml.etree.ElementTre ...
  • 在學習Python的是後遇到點小問題,記錄下來以後忘了再來看看。 一. python2 和python3在繼承父類的時候是不同的。super() 是一個特殊的函數,幫助Python將父類和子類關聯起來。在Python3中,直接使用如下代碼: Python3 在Python2中有兩種方法: 第一種 第 ...
  • Python 入門 之 反射 通過字元串操作對象的屬性和方法 對象的角度使用反射 類的角度使用反射 當前模塊使用反射 其他模塊使用反射 反射的應用場景 ...
  • ``` include int main(void) { int arr[10]={5,4,7,9,2,3,1,6,10,8}; //定義一個位排序的數組 int i; //定義迴圈次數 int n = 0; //定義排序次數 int length=10; //定義數組長度 while(n arr[ ...
  • 一、random模塊 random模塊是用來生成隨機數的。 練習:生成隨機驗證碼 import random def v_code(): code = '' for i in range(5): num=random.randint(0,9) alf=chr(random.randint(65,90 ...
  • 介面表示一種能力,實現了一個介面,即擁有一種能力。 BeanDefinition與Bean的關係, 就好比類與對象的關係. 類在spring的數據結構就是BeanDefinition.根據BeanDefinition得到的對象就是我們需要的Bean. 我認為理解Bean與BeanDefinition ...
  • @EnableAutoConfiguration註解是Spring Boot中配置自動裝載的總開關。本文將從@EnableAutoConfiguration入手,嘗試分析Spring Boot對@AutoConfigurationImportSelector註解的處理過程。 ...
一周排行
  • 微信公眾號: "Dotnet9" ,網站: "Dotnet9" ,問題或建議: "請網站留言" , 如果對您有所幫助: "歡迎贊賞" 。 .NET CORE(C ) WPF 值得推薦的動畫菜單設計 閱讀導航 1. 本文背景 2. 代碼實現 3. 本文參考 4. 源碼 1. 本文背景 YouTube上 ...
  • 1. HttpRequest對象 伺服器接收到http協議的請求後,會根據報文創建HttpRequest對象,這個對象不需要我們創建,直接使用伺服器構造好的對象就可以。視圖的第一個參數必須是HttpRequest對象,在django.http模塊中定義了HttpRequest對象的API。 1.1 ...
  • SpringMVC 攔截器 Spring MVC也可以使用攔截器對請求進行攔截處理,可以自定義攔截器來實現特定的功能,自定義的攔截器可以實現HandlerInterceptor介面中的三個方法,也可以繼承HandlerInterceptorAdapter 適配器類按照需要那個方法,就實現哪個方法 過 ...
  • 1. JDBC介紹 JDBC(Java DataBase Connectivity),即Java資料庫的連接。JDBC是一種用於執行SQL語句(DML,DDL,DQL)的Java API,可以為多種關係資料庫(oracle,mysql,sqlserver)提供統一訪問,它由一組用Java語言編寫的類 ...
  • [toc] 一、入門 1、Spring Boot簡介 簡化Spring應用開發的一個框架 整個Spring技術棧的整合 J2EE開發的一站式解決方案 2、微服務 Martin Fowler 微服務是一種架構風格 一個應用應該是一組小型服務:可以通過HTTP的方式進行互通 每一個功能元素最終都是一個可 ...
  • 首先如果直接使用 root 用戶來啟動 tomcat 的話,是可以正常啟動的。 但是我們在 Linux 中使用普通用戶啟動 tomcat 報瞭如下錯誤 原因是沒有在 setclasspath.sh 上設置 JAVA_HOME 和 JRE_HOME。 解決辦法: 打開 setclasspath.sh ...
  • 線上實時轉換 需要 .babelrc中: 項目中main.js配置: 前提是安裝對應的包 自己寫的要運行的為app.js,這樣配置後會在運行main.js是自動轉為es5並執行 通過配置手動轉換 需要 安裝babel後 運行 src為自己寫的es6目錄文件,dist為轉碼後的es5文件,沒有則創建 ...
  • 假如有兩個文件:app.js和config.js app.js為主文件要去引用config這個模塊 以前學習node時使用的模塊導出: es6中的模塊導出 方法一 兩種可以混合使用 方法二 通過 export 導出的成員必須通過解構賦值按需載入 或者通過 的形式載入所有通過 export 關鍵字導出 ...
  • 不做解釋,代碼一看就懂 app.js config.js ...
  • 對babel進行複習
x