面試最常問的數組轉樹,樹轉數組 c++ web框架paozhu實現

来源:https://www.cnblogs.com/paozhu/archive/2023/04/24/17350533.html
-Advertisement-
Play Games

教程簡介 GWT Highcharts是一個基於 Java 的開源庫,可在 GWT 應用程式中提供優雅且功能豐富的 Highcharts 可視化,並可與 GWT 小部件庫一起使用。 GWT Highcharts入門教程 - 從基本概念到高級概念,從簡單的步驟瞭解GWT Highcharts,其中包括 ...


剛畢業同學,找工作常被問 二維數組轉樹,樹轉二維數組 需要支持無限層級實現,如果你瞭解這個語言那麼實現起來還要一番思考

c++ web框架 paozhu使用 需要實現資料庫表數據到前臺菜單實現,就是這種功能 二維數組轉樹,樹轉二維數組 保存時候樹二維數組,展示時候樹樹狀。

這個技術難點在於無限遞歸,這個樹程式基本原理

現在看看c++怎麼實現的,無限遞歸,家肯定是考慮到結構體 嵌套自己定義。

struct department_outjson_t
{
  unsigned int id          = 0;
  unsigned int parentid    = 0;
  bool isopen              = true;
  bool _is_use             = false;
  std::string title;
  std::string desc;
  std::vector<department_outjson_t> children;

};
department_outjson_t 就是結構體 嵌套定義
我們看看怎麼實現的,先上代碼,使用了模板

template <typename deps_json_type>
concept ishas_isuse_member = requires(deps_json_type m) { m._is_use; };

template <typename deps_json_type>
  requires ishas_isuse_member<deps_json_type>
void array_to_tree(std::vector<deps_json_type> &targetdata,
                   std::vector<deps_json_type> &sourcedata)
{

  if (targetdata.size() == 0)
  {
    for (unsigned int i = 0; i < sourcedata.size(); i++)
    {
      if (sourcedata[i].parentid == 0)
      {
        targetdata.push_back(sourcedata[i]);
        sourcedata[i]._is_use = true;
      }
    }
  }

  for (unsigned int i = 0; i < sourcedata.size(); i++)
  {
    if (sourcedata[i]._is_use == false)
    {
      for (unsigned int j = 0; j < targetdata.size(); j++)
      {
        if (targetdata[j].id == sourcedata[i].parentid)
        {
          targetdata[j].children.push_back(sourcedata[i]);
          sourcedata[i]._is_use = true;
          array_to_tree(targetdata[j].children, sourcedata);
        }
      }
    }
  }
}

 

就是這樣可以實現了,註意是使用了掃描,怕影響性能,我用一個變數標註,當然也可以用保存地址方式。

 

順便把 樹轉二維數組也實現了

template <typename deps_json_type>
void tree_to_array(std::vector<deps_json_type> &targetdata,
                   std::vector<deps_json_type> &sourcedata,
                   unsigned int parendid = 0)
{

  for (unsigned int i = 0; i < sourcedata.size(); i++)
  {
    if (sourcedata[i].parentid == parendid)
    {
      if (sourcedata[i].children.size() > 0)
      {
        deps_json_type temp = sourcedata[i];
        temp.children.clear();
        targetdata.push_back(temp);
        tree_to_array(targetdata, sourcedata[i].children, sourcedata[i].id);
      }
      else
      {
        targetdata.push_back(sourcedata[i]);
      }
    }
  }
}

 

這樣給前端api多爽,前端也不用自己處理,每次提交整個樹過來就可以了,看完是不是明白了,主要是控制id 和 parentid

更多paozhu有趣特性 以後一一介紹。

✅ 1. 自帶json編解碼不用第三方庫,標準json支持
✅ 2. 支持多功能變數名稱網站
✅ 3. 支持多功能變數名稱ssl 服務端
✅ 4. 支持http/1.1、http/2協議
✅ 5. 支持websocket服務端
✅ 6. 框架自帶websocket推送,支持定時推送到webscoket客戶端
✅ 7. 支持同步httpclient get post
✅ 8. 框架自帶ORM,使用鏈接池方式,目前支持mysql
✅ 9. 框架自帶線程池,和用戶代碼運行的線程池
✅10. 框架使用asio自帶的協程
✅11. 框架特色是I/O 使用協程池 用戶代碼運行使用線程池,類似GO那種調度,只是針對http請求調度
✅12. 框架支持普通文件gzip、br,並支持緩存到磁碟,下次不用cpu再壓縮
✅13. 框架解析URL和POST,解析結果類似PHP GET POST方式獲取內容
✅14. 自帶sendmail類庫
✅15. 生成二維碼(qrcode),需要gd、qrencode庫
✅16. 插件化編程,熱動態更新,使用動態庫方式
✅17. 框架內置通用數據緩存模塊,ORM結果緩存,提高併發能力
✅18. 框架controller目錄註解功能,方便添加URL路由映射,降低入門心智
✅19. 結構和類註解JSON功能,使用json_encode json_decode操作

 

https://github.com/hggq/paozhu

 


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

-Advertisement-
Play Games
更多相關文章
  • 簡介 原型模式(Prototype Pattern)是一種創建型設計模式,使你能夠複製已有對象,而無需使代碼依賴它們所屬的類,同時又能保證性能。 這種模式是實現了一個原型介面,該介面用於創建當前對象的克隆。當直接創建對象的代價比較大時,則採用這種模式。 如果你需要複製一些對象,同時又希望代碼獨立於這 ...
  • 閱讀原文:https://bysocket.com/openai-chatgpt-vs-developer/ ChatGPT 能取代多少程式員的工作?導致我們程式員失業嗎?這是一個很好的話題,我這裡分享下: 一、ChatGPT 是什麼?有什麼作用 ChatGPT是一種基於人工智慧技術的語言模型,是可 ...
  • 環境:CentOS 7.6_x64Python版本:3.9.12FreeSWITCH版本 :1.10.9 一、背景描述 ESL庫是FreeSWITCH對外提供的介面,使用起來很方便,但該庫是基於C語言實現的,Python使用該庫的話需要使用源碼進行編譯。如果使用系統自帶的Python版本進行編譯,過 ...
  • 高級特性 主要內容 不安全 Rust 高級 Trait 高級 類型 高級函數和閉包 巨集 一、不安全 Rust 匹配命名變數 隱藏著第二個語言,它沒有強制記憶體安全保證:Unsafe Rust(不安全的 Rust) 和普通的 Rust 一樣,但提供了額外的“超能力” Unsafe Rust 存在的原因: ...
  • 這一年乾的很多事都是為了降低我的開源項目消息推送平臺austin使用門檻。 如果想學Java項目的,強烈推薦我的開源項目消息推送平臺Austin(8K stars) ,可以用作畢業設計,可以用作校招,可以看看生產環境是怎麼推送消息的。開源項目消息推送平臺austin倉庫地址: 消息推送平臺🔥推送下 ...
  • Codable 是 Swift 4.0 引入的一種協議,它是一個組合協議,由 Decodable 和 Encodable 兩個協議組成。它的作用是將模型對象轉換為 JSON 或者是其它的數據格式,也可以反過來將 JSON 數據轉換為模型對象。 ...
  • 1,局部變數與全局變數 1,定義 局部變數:就是在函數體內的變數,在python中冒號“:”後面的變數都是局部變數,當然局部與全局也是一個相對的概念。比如出現函數嵌套的情況。 全局變數:就是在模塊中所有函數都可以調用的變數,一般在函數體外被定義。 2,使用過程 函數內的局部變數,在函數體外是不可以使 ...
  • 〇、Maven 0.1 什麼是Maven? Apache Maven is a software project management and comprehension tool. Based on the concept of a project object model (POM), Mave ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...