演算法第一章作業

来源: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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...