php算法-- 關聯數組使用,優化sip賬號去重

文章目錄

      • 1 變量定義
      • 2. 核心特性
      • code

1 變量定義

  • 類型:嵌套的關聯數組(Nested Associative Array)
  • 外層結構:[中繼ID => 賬號列表]
  • 鍵 (Key):中繼ID(字符串或整型)
  • 值 (Value):索引數組(包含屬于該中繼的所有SIP賬號字符串)

內存形態:
php
[
“中繼ID_A” => [“賬號1”, “賬號2”, …],
“中繼ID_B” => [“賬號X”, “賬號Y”, …]
]


數據結構存儲
// 初始狀態
$existingAccounts = [
“2” => [“1001”],
“5” => [“2001”]
];

// 添加新賬號到中繼2
$existingAccounts[“2”][] = “1002”;

// 添加新中繼組
$existingAccounts[“9”] = [“3001”];

// 最終形態
[
“2” => [“1001”, “1002”],
“5” => [“2001”],
“9” => [“3001”]
]


2. 核心特性

特性說明
按中繼分組以中繼ID為分組維度,天然隔離不同中繼的賬號
值唯一性同一中繼組內SIP賬號強制唯一(通過數組值隱式保證)
O(1)快速檢索通過isset($existingAccounts[$trunkIdx])可瞬間判斷中繼是否存在
O(n)成員檢查通過in_array($account, $existingAccounts[$trunkIdx])檢查賬號重復性

in_array解析:

$needle:要搜索的值(示例中的 SIP 賬號)
$haystack:被搜索的數組(示例中的 $existingAccounts[$trunkIdx])
bool in_array(mixed $needle, array $haystack [, bool $strict = false])

code

1 基礎功能:賬號添加

// 檢查中繼組是否存在
if (!isset($existingAccounts[$trunkIdx])) {// 新建中繼分組(初始化空數組)$existingAccounts[$trunkIdx] = [];
}// 添加賬號到中繼組
$existingAccounts[$trunkIdx][] = $account;

2 去重高效性 ,添加新賬號時,只需兩步驗證

$trunkIdx = "2";  // 目標中繼
$newAccount = "1002";if (isset($existingAccounts[$trunkIdx]) && in_array($newAccount, $existingAccounts[$trunkIdx])) {// 賬號已存在 → 拒絕添加
} else {// 安全添加賬號
}

3 函數封裝

// 新增賬號時防重復檢查
function addAccount($trunkIdx, $account) {global $existingAccounts;if (isset($existingAccounts[$trunkIdx]) {if (in_array($account, $existingAccounts[$trunkIdx])) {throw new Exception("賬號 $account 已存在于中繼 $trunkIdx");}} else {$existingAccounts[$trunkIdx] = []; // 初始化新中繼組}// 安全添加賬號$existingAccounts[$trunkIdx][] = $account;
}// 示例:添加重復賬號(觸發異常)
addAccount("2", "1001");  // 拋出異常:賬號1001已存在于中繼2

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

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

相關文章

LLM 多語言數據集

多語言數據感覺主要還是fineweb和fineweb2, 其他數據都是主要針對特定語種比較多 101 Billion Arabic Words Dataset ClusterlabAi/101_billion_arabic_words_dataset 數據主要從e Common Crawl WET 中提取,并采用了創新的技術來進行去重和篩選,主要解決…

【HarmonyOS Next之旅】DevEco Studio使用指南(三十六) -> 配置構建(三)

目錄 1 -> 定制HAR多目標構建產物 1.1 -> 定義產物的deviceType 1.2 -> 定義C工程依賴的.so文件 1.3 -> 定義產物的資源 2 -> 配置APP多目標構建產物 2.1 -> 定義產物的APP包名和供應商名稱 2.2 -> 定義product的bundleName 2.3 -> 定義produc…

數據賦能(340)——技術平臺——共享平臺

概述重要性如下:提高數據利用效率:數據共享平臺能夠將分散在各部門的數據進行集中管理,促進數據流通和共享,避免數據孤島現象,從而提高數據利用效率。促進決策科學化:通過共享平臺,各部門可以獲…

開閉原則在C++中的實現

開閉原則(Open/Closed Principle,簡稱 OCP)是面向對象設計中的一個重要原則,屬于“SOLID”原則之一。它的核心思想是:“軟件實體(如類、模塊、函數等)應該對擴展開放,對修改關閉。”…

C語言:*p++與p++有何區別

1. 指針基礎練習&#xff1a;演示p、p和(*p)的區別核心目的&#xff1a;區分指針自增與指針指向值自增的不同邏輯&#xff0c;理解運算符優先級對指針操作的影響。#include <stdio.h>void arr1() {int arr[] {11,13,15,17,19};int *p arr;printf("結果1&#xff1…

【設計】設計一個web版的數據庫管理平臺后端(之二)

在之前&#xff0c;我寫過一篇【設計】設計一個web版的數據庫管理平臺后端精要 的文章&#xff0c;文章講了一個web版數據庫管理平臺的實現思路及主要代碼。 最近&#xff0c;我看了下Mybatis的源碼&#xff0c;覺得Mybatis的分層架構挺好&#xff0c;所以想到了完善下web版數據…

Visual tudio 各版本下 C++ 開發的核心區別與實踐指南

C語言的發展經歷了數十年的演進&#xff0c;從 C98 到現代的 C20/23&#xff0c;語言本身發生了巨大的變革。與此同時&#xff0c;Visual Studio 作為主流的 C 開發環境之一&#xff0c;其編譯器對各個 C 標準的支持程度也隨版本不斷演進&#xff0c;直接影響著開發者的編程方式…

怎樣讓阿里云服務器(centos)有界面

要讓阿里云服務器 CentOS 有圖形界面&#xff0c;可以按照以下步驟進行操作&#xff1a;登錄服務器&#xff1a;使用 SSH 客戶端工具&#xff0c;通過 IP 地址和賬號登錄到阿里云服務器。更新系統軟件源&#xff1a;輸入命令sudo yum update&#xff0c;更新系統軟件源&#xf…

Qt 異步編程模式與應用

在現代軟件開發中&#xff0c;異步編程已成為提升應用性能和響應性的關鍵技術。Qt 作為一個強大的跨平臺框架&#xff0c;提供了多種異步編程模式&#xff0c;包括信號槽機制、事件循環、線程池、異步 I/O 等。本文將深入探討 Qt 異步編程的各種模式及其應用場景&#xff0c;幫…

面試150 數字范圍按位與

思路 只要 left < right&#xff0c;說明兩者在某些低位上存在不同&#xff0c;為了找到它們的公共前綴&#xff08;高位相同部分&#xff09;&#xff0c;不斷將 left 和 right 同時右移&#xff08;即除以2&#xff09;&#xff0c;直到它們相等&#xff0c;記錄右移的次數…

數據庫HB OB mysql ck startrocks, ES存儲特點,以及應用場景

這些數據庫和存儲引擎主要有:HB(HBase)、OB(OceanBase)、MySQL、ClickHouse(CK)、StarRocks、Elasticsearch(ES),下面分別介紹它們的存儲特點以及典型應用場景。 1. HBase (HB) 存儲特點 分布式、面向列的NoSQL數據庫 采用HDFS存儲,數據以表、row key、列族、時間戳…

Java技術棧/面試題合集(17)-Git篇

場景 Java入門、進階、強化、擴展、知識體系完善等知識點學習、性能優化、源碼分析專欄分享: Java入門、進階、強化、擴展、知識體系完善等知識點學習、性能優化、源碼分析專欄分享_java高級進階-CSDN博客 通過對面試題進行系統的復習可以對Java體系的知識點進行查漏補缺。…

破局與重構:King’s LIMS 引領電子行業實驗室智能化轉型

在全球化高新技術競爭白熱化背景下&#xff0c;電子行業正經歷從規模導向擴張向質量效益躍升的戰略轉型。終端用戶對產品性能的極致化追求、行業質量合規標準的持續迭代升級&#xff0c;以及檢測數據的指數級增長&#xff0c;共同形成"需求牽引供給、供給創造需求"的…

暑期算法訓練.9

目錄 43 .力扣75 顏色分類 43.1 題目解析&#xff1a; 43.2 算法思路&#xff1a; 43.3 代碼演示&#xff1a; 43.4 總結反思&#xff1a; 44. 力扣 912 排序數組 44.1 題目解析&#xff1a; 44.2 算法思路&#xff1a; 44.3 代碼演示&#xff1a; ?編輯 44.4 總結反…

2.安裝CUDA詳細步驟(含安裝截圖)

2.安裝CUDA 第一步&#xff1a;安裝anaconda 注意&#xff1a;安裝CUDA之前需要安裝好anaconda&#xff0c;詳見安裝anaconda詳細步驟&#xff08;含安裝截圖&#xff09; 文章目錄2.安裝CUDA2.0 CUDA是什么&#xff0c;為什么要安裝它&#xff1f;2.1 驗證計算機是否安裝CUDA2…

Triton IR

Triton IR語法 Triton IR的語句遵從MLIR Dialect的語法定義規范&#xff0c;示例如下&#xff1a; %3 tt.splat %1 : i32 -> tensor<1024xi32> loc(#loc5) 其中&#xff1a; %0&#xff1a;右邊expression的結果值的名字&#xff08;Value的name&#xff09; tt…

掌握JavaScript函數封裝與作用域

JavaScript 基礎 - 第4天筆記理解封裝的意義&#xff0c;能夠通過函數的聲明實現邏輯的封裝&#xff0c;知道對象數據類型的特征&#xff0c;結合數學對象實現簡單計算功能。理解函數的封裝的特征掌握函數聲明的語法理解什么是函數的返回值知道并能使用常見的內置函數函數理解函…

Datawhale AI 夏令營—科大訊飛AI大賽(大模型技術)—讓大模型理解表格數據(列車信息表)

目錄 一、本次賽事目標&#xff1a;讓大模型理解表格數據&#xff08;列車信息表&#xff09; 二、分析賽題、對問題進行建模 賽事背景 賽題解讀 數據分析與探索 賽題要點與難點 解題思考過程 三、Baseline方案 Baseline概況 Baseline運行步驟 Baseline文件概況 Ba…

SSH連接失敗排查與解決教程: Connection refused

前言 當使用云服務器&#xff08;如阿里云、騰訊云、AWS 等&#xff09;時&#xff0c;嘗試在本地PC端使用圖形化工具如 FinalShell、XShell可能會遇到 SSH 連接失敗的問題。本文列舉 SSH 連接失敗的常見原因&#xff0c;并提供對應解決方案&#xff0c;幫助快速定位并解決問題…

性能優化:Vue 3 `v-memo` 指令詳解

v-memo 是 Vue 3 提供的一個性能優化工具&#xff0c;能幫助開發者緩存模板內容&#xff0c;減少不必要的渲染開銷。本文將介紹 v-memo 的引入版本、作用、使用方法和實現原理&#xff0c;并通過示例說明如何使用它。內容基于 Vue 3.5.18&#xff08;截至 2025 年 7 月的最新版…