系統設計題-路由表最長匹配

一、題目

路由表最長匹配:將目標IP地址dstIP與路由為entryIP/掩碼長度m(比如10.166.50.0/23)進行匹配,找出匹配掩碼m最長值。
匹配規則
如果dstIP和entryIP的二進制表示的前m個位相同,則說明是匹配的。
0.0.0.0是默認路由,與任何dstIP均匹配,m值為0。
所有匹配的路由中,m的最大值即為“最長匹配”

二、樣例

第一行是dstIP
第二行是總entryIP數
第三行之后是具體的entryIP/m

192.168.0.3
6
10.166.50.0/23
192.0.0.0/0
10.255.255.255/32
192.168.0.1/24
127.0.0.0/0
192.168.0.0.0/24
輸出
192.168.0.1/24

三、代碼實現

    // ipTable是個二維數組,每一個數組中第0列存IP,第1列存掩碼private static String routeSearch(String dstIp, String[][] ipTable) {String dstIpBinary = getRoute(dstIp);LinkedList<String> maxMatchList = new LinkedList<>();int maxMatch = -1;for (String[] strings : ipTable) {String tempRoute = strings[0];int maxNum = Integer.parseInt(strings[1]);if (tempRoute.equals("0.0.0.0") && maxNum == 0) {maxMatch = maxNum;maxMatchList.add(tempRoute + "/" + maxNum);continue;}if (isMatch(dstIpBinary, getRoute(tempRoute), maxNum) && maxNum > maxMatch) {maxMatchList.clear();maxMatch = maxNum;maxMatchList.add(tempRoute + "/" + maxNum);}}if (maxMatchList.isEmpty()) {return "empty";}return maxMatchList.getFirst();}// 判斷在給定matchNum長度下,是否匹配private static boolean isMatch(String src, String ds, int matchNum) {for (int i = 0; i < matchNum; i++) {if (src.charAt(i) != ds.charAt(i)) {return false;}}return true;}// 將IP地址轉換成二進制private static String getRoute(String s) {String[] ipSplit = s.split("\\.");StringBuilder stringBuilder = new StringBuilder();for (String ip : ipSplit) {// 轉換成二進制,不足8位,則補0String binaryString = Integer.toBinaryString(Integer.parseInt(ip));String formatBinaryStr = String.format("%8s", binaryString);formatBinaryStr = formatBinaryStr.replace(" ", "0");stringBuilder.append(formatBinaryStr);}return stringBuilder.toString();}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/44783.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/44783.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/44783.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

抖音必備工具!掌握螢瓴優選櫥窗帶貨軟件的五大優勢,助你快速盈利

在當今數字化時代&#xff0c;抖音作為一款備受歡迎的短視頻社交平臺&#xff0c;不僅為人們提供了展示自我的舞臺&#xff0c;更成為了眾多商家和個人創業者推廣產品和服務的重要渠道。然而&#xff0c;要在抖音上實現高效帶貨&#xff0c;并非易事。幸運的是&#xff0c;螢瓴…

技校專業群的生成機制研究

一、引言 隨著我國經濟的快速發展和產業結構的不斷優化&#xff0c;技術型人才的需求日益旺盛。技工學校&#xff08;簡稱技校&#xff09;作為培養技術型人才的搖籃&#xff0c;其專業群的構建與發展顯得尤為重要。專業群作為技校戰略發展的核心&#xff0c;不僅能夠優化教學…

Python 腳本編寫指南:從框架到實踐

一、引言 Python 作為一種強大且易于學習的編程語言&#xff0c;在各個領域都有著廣泛的應用。編寫 Python 腳本是實現各種功能和任務的常見方式。 二、Python 腳本框架的基本組成部分 導入必要的模塊 在腳本的開頭&#xff0c;我們通常需要導入所需的 Python 模塊&#xff…

大模型之戰進入新賽季,開始卷應用

最近一段時間&#xff0c;國產大模型Kimi徹底火了&#xff0c;而這波爆火&#xff0c;某種意義上也展示了一個問題&#xff0c;即大模型的落地場景可能比技術比拼&#xff0c;更重要。 國產大模型Kimi突然爆火&#xff0c;與Kimi相關的產業鏈甚至被冠上“Kimi概念股”之名&…

【初階數據結構】樹與二叉樹:從零開始的奇幻之旅

初階數據結構相關知識點可以通過點擊以下鏈接進行學習一起加油&#xff01;時間與空間復雜度的深度剖析深入解析順序表:探索底層邏輯深入解析單鏈表:探索底層邏輯深入解析帶頭雙向循環鏈表:探索底層邏輯深入解析棧:探索底層邏輯深入解析隊列:探索底層邏輯深入解析循環隊列:探索…

day10:03 一文搞懂encode和encoding的區別

在Python中&#xff0c;處理字符串時經常會遇到encode()方法和encoding參數&#xff0c;它們都與字符串的編碼和解碼有關&#xff0c;但用途和上下文有所不同。下面通過案例來解釋它們的關系和區別。 1. encode() 方法 encode()方法是字符串&#xff08;str&#xff09;類型的…

《簡歷寶典》08 - 簡歷中“教育背景”模塊如何揚長避短

目錄 1 本文概述 2 必須寫的信息 3 學歷的優勢凸顯 4 專業的重要性 5 如果所學專業與當前求職的職位不匹配 6 在校期間獲得的獎項和證書 7 最后 1 本文概述 前兩節我們把個人信息模塊做了拆分講解&#xff0c;分為必寫的信息項和根據個人情況酌情添加的信息項&#xff0…

51單片機:如何使用串口波特率計算器及其詳解

目錄 一、如何使用串口波特率計算器 1.以此為例: 2.生成代碼如下: 3.需要手動配置中斷系統 1.原理圖 2.配置代碼 二、如何理解軟件生成的波特率 1.以該代碼為例子進行分析 2.串口模式圖 三、如何計算波特率 參考STC89C52手冊P235 四、如何調用串口中斷函數 一、如何…

HBase 在統一內容平臺業務的優化實踐

作者&#xff1a;來自 vivo 互聯網服務器團隊-Leng Jianyu、Huang Haitao HBase是一款開源高可靠性、擴展性、高性能和靈活性的分布式非關系型數據庫&#xff0c;本文圍繞數據庫選型以及使用HBase的痛點展開&#xff0c;從四個方面對HBase的使用進行優化&#xff0c;取得了一些…

36. Adam 算法詳解

Adam&#xff08;Adaptive Moment Estimation&#xff09;是一種結合動量法和自適應學習率的優化算法&#xff0c;自2014年提出以來&#xff0c;迅速成為深度學習中最流行和常用的優化算法之一。Adam算法的核心思想是利用梯度的一階動量和二階動量來動態調整學習率&#xff0c;…

基于jeecgboot-vue3的Flowable流程-集成仿釘釘流程(五)仿釘釘流程的json數據保存與顯示

因為這個項目license問題無法開源&#xff0c;更多技術支持與服務請加入我的知識星球。 1、需要做一個界面保存與顯示仿釘釘的流程&#xff0c;先建一個表&#xff0c;用online建 2、通過上面生成代碼&#xff0c;放入到相應的前后端工程里 3、修改前端仿釘釘流程的設計功能&a…

spark基于Spark的對招聘信息的分析與設計-計算機畢業設計源碼50716

目 錄 摘要 1 緒論 1.1 研究背景 1.2 研究意義 1.3論文結構與章節安排 2 系統分析 2.1 可行性分析 2.2.1 數據新增流程 2.2.2 數據刪除流程 2.3 系統功能分析 2.3.1 功能性分析 2.3.2 非功能性分析 2.4 系統用例分析 2.5本章小結 3 系統總體設計 3.1 系統架構設…

Vue2/Vue3實現全局/局部添加防篡改水印的效果。刪除元素無效!更改元素屬性無效!支持圖片、元素、視頻等等。

水印目的 版權保護:水印可以在圖片、文檔或視頻中嵌入作者、品牌或版權所有者的信息,以防止未經授權的復制、傳播或使用。當其他人使用帶有水印的內容時,可以追溯到原始作者或版權所有者,從而加強版權保護。 身份識別:水印可以用作作者或品牌的標識符,使觀眾能夠輕松識…

springboot對ZonedDateTime返回結果json是string-源碼分析

springboot對ZonedDateTime返回結果json是string-源碼分析 application/json格式默認使用ObjectMapper實例進行序列化ObjectMapper自動注入分析springboot關于jackson配置 java.time.ZonedDateTime application/json格式默認使用ObjectMapper實例進行序列化 controller返回后&…

人形機器人的理想與現實

李開復曾提到過一個AI界流傳的“騙子又來了曲線”。 人會不斷給機器進行“是否具有人類智能”的鑒定&#xff0c;而這個過程&#xff0c;總是從被人工智能在某些領域的驚艷表現震撼&#xff0c;到逐漸認識到當時的人工智能還有各種局限&#xff0c;以至于產生巨大心理落差。 近…

html js 3d z軸移動 實現星空

用chatgpt還有kimi 讓實現動畫效果的星空,都太垃圾了 不是y軸移動,就是x軸移動, 我要z軸移動,他們就是搞不出來, ai寫代碼還有很長的路。 <!DOCTYPE html> <meta charset="utf-8" /> <head> <title>ai相關博客</title> </h…

【操作系統】手把手帶你搭建DNS服務器!

DNS服務器 DNS服務器指域名系統或者域名服務。域名系統為Internet上的主機分配域名地址和IP地址&#xff0c;用戶使用域名地址&#xff0c;該系統就會自動把域名地址轉為IP地址。域名服務是運行域名系統的Internet工具。執行域名服務的服務器稱之為DNS服務器&#xff0c;通過DN…

51單片機嵌入式開發:8、 STC89C52RC 操作LCD1602原理

STC89C52RC 操作LCD1602原理 1 LCD1602概述1.1 LCD1602介紹1.2 LCD1602引腳說明1.3 LCD1602指令介紹 2 LCD1602外圍電路2.1 LCD1602接線方法2.2 LCD1602電路原理 3 LCD1602軟件操作3.1 LCD1602顯示3.2 LCD1602 protues仿真 4 總結 1 LCD1602概述 1.1 LCD1602介紹 LCD1602是一種…

maven——(重要)手動創建,構建項目

創建項目 手動按照maven層級建好文件夾&#xff0c;并寫上java&#xff0c;測試代碼和pom文件 構建項目 在dos窗口中執行如下命令 compile編譯 當前maven倉庫中什么都沒有。 在pom所在層級下&#xff0c;執行&#xff1a; mvn compile 就開始顯示下面這些&#xff0c;…

數據庫-ubuntu環境下安裝配置mysql

文章目錄 什么是數據庫&#xff1f;一、ubuntu環境下安裝mysql二、配置mysql配置文件1.先登上root賬號2.配置文件的修改show engines \G; mysql和mysqld數據庫的基礎操作登錄mysql創建數據庫顯示當前數據庫使用數據庫創建表插入students表數據打印students表數據select * from …