演算法第一章作業

来源:https://www.cnblogs.com/Remilia-Scarlet/archive/2019/08/31/11440472.html
-Advertisement-
Play Games

一:代碼規範 參考 :https://zh-google-styleguide.readthedocs.io/en/latest/google-cpp-styleguide/headers/# 1 . 頭文件 1.1. Self-contained 頭文件 頭文件應該能夠自給自足(self-cont ...


一:代碼規範

  參考 :https://zh-google-styleguide.readthedocs.io/en/latest/google-cpp-styleguide/headers/#

  1 . 頭文件

    1.1. Self-contained 頭文件

  頭文件應該能夠自給自足(self-contained,也就是可以作為第一個頭文件被引入),以 .h 結尾。至於用來插入文本的文件,說到底它們並不是頭文件,所以應以 .inc 結尾。不允許分離出 -inl.h 頭文件的做法.

    1.2. #define 保護

  所有頭文件都應該使用 #define 來防止頭文件被多重包含, 命名格式當是: <PROJECT>_<PATH>_<FILE>_H_ .

    1.3.  前置聲明

  儘可能地避免使用前置聲明。使用 #include 包含需要的頭文件即可。

    1.4. 內聯函數

  只有當函數只有 10 行甚至更少時才將其定義為內聯函數.

    1.5. #include 的路徑及順序

  使用標準的頭文件包含順序可增強可讀性, 避免隱藏依賴: 相關頭文件, C 庫, C++ 庫, 其他庫的 .h, 本項目內的 .h.

  2 . 作用域

    2.1. 命名空間

  鼓勵在 .cc 文件內使用匿名命名空間或 static 聲明. 使用具名的命名空間時, 其名稱可基於項目名或相對路徑. 禁止使用 using 指示(using-directive)。禁止使用內聯命名空間(inline namespace)。

    2.2. 匿名命名空間和靜態變數

  在 .cc 文件中定義一個不需要被外部引用的變數時,可以將它們放在匿名命名空間或聲明為 static 。但是不要在 .h 文件中這麼做。

    2.3. 非成員函數、靜態成員函數和全局函數

  使用靜態成員函數或命名空間內的非成員函數, 儘量不要用裸的全局函數. 將一系列函數直接置於命名空間中,不要用類的靜態方法模擬出命名空間的效果,類的靜態方法應當和類的實例或靜態數據緊密相關.

    2.4. 局部變數

  將函數變數儘可能置於最小作用域內, 併在變數聲明時進行初始化.

    2.5. 靜態和全局變數

  禁止定義靜態儲存周期非POD變數,禁止使用含有副作用的函數初始化POD全局變數,因為多編譯單元中的靜態變數執行時的構造和析構順序是未明確的,這將導致代碼的不可移植。

  3.類

    3.1. 構造函數的職責

  不要在構造函數中調用虛函數, 也不要在無法報出錯誤時進行可能失敗的初始化.

    3.2.  隱式類型轉換

  不要定義隱式類型轉換. 對於轉換運算符和單參數構造函數, 請使用 explicit 關鍵字.

    3.3. 可拷貝類型和可移動類型

  如果你的類型需要, 就讓它們支持拷貝 / 移動. 否則, 就把隱式產生的拷貝和移動函數禁用.

    3.4. 結構體 VS. 類

  僅當只有數據成員時使用 struct, 其它一概使用 class.

    3.5. 繼承

  使用組合 (YuleFox 註: 這一點也是 GoF 在 <<Design Patterns>> 里反覆強調的) 常常比使用繼承更合理. 如果使用繼承的話, 定義為 public 繼承.

  4.格式

    4.1. 行長度

  每一行代碼字元數不超過 80.

    4.2. 條件語句

  傾向於不在圓括弧內使用空格. 關鍵字 if 和 else 另起一行.

  舉例:if (condition) {

    4.3. 布爾表達式

  如果一個布爾表達式超過標準行寬, 斷行方式要統一 一下.

  如:if (..... &&

     ..... &&

        .....) {

       ....

    }

    4.4. 函數聲明與定義

  註意以下幾點:

 

  • 使用好的參數名.
  • 只有在參數未被使用或者其用途非常明顯時, 才能省略參數名.
  • 如果返回類型和函數名在一行放不下, 分行.
  • 如果返回類型與函數聲明或定義分行了, 不要縮進.
  • 左圓括弧總是和函數名在同一行.
  • 函數名和左圓括弧間永遠沒有空格.
  • 圓括弧與參數間沒有空格.
  • 左大括弧總在最後一個參數同一行的末尾處, 不另起新行.
  • 右大括弧總是單獨位於函數最後一行, 或者與左大括弧同一行.
  • 右圓括弧和左大括弧間總是有一個空格.
  • 所有形參應儘可能對齊.
  • 預設縮進為 2 個空格.
  • 換行後的參數保持 4 個空格的縮進.

 

  5. 註釋

    5.1. 類註釋

  每個類的定義都要附帶一份註釋, 描述類的功能和用法, 除非它的功能相當明顯.

    5.2. 實現註釋

  對於代碼中巧妙的, 晦澀的, 有趣的, 重要的地方加以註釋.


二、《數學之美系列十三 — 信息指紋及其應用》 讀後感

   任何一段信息文字,都可以對應一個不太長的隨機數,作為區別它和其他信息的指紋。這種映射真是太美妙了,把一個一百多個字元的網址隨機地映射到128二進位位的正數中,這樣子處理後就可以把存儲網址的記憶體需求量從原來的一百多個位元組轉變成16個位元組,而這種產生隨機數的演算法,是其中的核心。數學的加減乘除,只要按照一定的規則處理,就可以形成一種好的映射,讓信息指紋不可逆,更好地保障了用戶的安全。學好數學,靈活運用數學規律,可以幫助我們更好地解決現實中的問題。

 


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

-Advertisement-
Play Games
更多相關文章
  • ZAB協議包括兩種基本的模式,分別是 崩潰恢復和消息廣播。當整個服務框架在啟動過程中,或是當 Leader 伺服器出現網路中斷、崩潰退出與重啟等異常情況時,ZAB 協議就會進人恢復模式並選舉產生新的Leader伺服器。當選舉產生了新的 Leader 伺服器,同時集群中已經有過半的機器與該Leader... ...
  • 在類中定義__slot__屬性來限制實例的屬性欄位,在創建大量對象的場合可以減少記憶體占用。 創建大量對象是記憶體占用對比: 執行結果: Line # Mem usage Increment Line Contents 401 39.7 MiB 39.7 MiB @profile() 402 def m ...
  • 總想寫點什麼,沒想好,先占個坑位 ...
  • os模塊 1.os.getcwd() 獲取當前工作目錄,即當前python腳本工作的目錄路徑 2.os.chdir() 改變當前腳本工作目錄;相當於shell下cd 3.os.makedirs() 用於遞歸創建目錄,內部有兩個參數path、mode(許可權模式) 代碼執行前: 代碼執行後: 4.os. ...
  • 源碼說明:這套系統比淘小秘、淘小白、E速達、好多了他們還要電腦開機並掛著軟體才能自動發貨,而這套系統完全可以秒殺這一切。安裝之前說明,如果你沒有新浪賬號的話請註冊好新浪賬號,網站名稱LOGO自備。本程式不限制功能變數名稱,單用戶版本,支持sae、bae、虛擬主機等使用之後買家拍下付款到網站提取了貨,淘寶就自 ...
  • Failed to configure a DataSource: 'url' attribute is not specified and no embedded datasource could be configured. ...
  • lambda表達式主要用於短小的回調函數。 形如: arg1[,arg2][,arg3][...]為參數列表。 expression表達式語句中不能出現多條語句。 lambda應用舉例: 計算最大值: 結果: 222 計算輸入的和: 結果: 232 ...
  • 題目傳送門 簡單分析一下題目,可以發現: 第一個數最小為123 第一個數最大為333,再大第三個數就是四位數了 所以可以這樣做: 然後我們可以將每個數的各個數位分離出來,再加到標記數組裡面: code: 另外,為了防止複製,我悄悄地在代碼中留了個小錯誤,能不能直接提交,就看你的啦! PS:如果發現了 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...