>[danger] 需要引入 `cstdio` 或 `stdio.h`
## 一.格式化輸入
1. 函數簡介
| 函數 | **int** scanf(**const char\*** format,...) |
| ---------- | ------------------------------------------------------------ |
| **功能** | 從標準輸入(stdin)讀取格式化輸入。若輸入緩沖區中沒有字符,則從系統隱含指定的輸入設備(鍵盤)中輸入一個字符。若輸入緩沖區中有字符,則不從緩沖區中讀取字符。 |
| **參數** | **const char** *format 格式化輸入字符串。格式轉換說明符以外的字符需要按原樣輸入。兩個數之間若無其他字符則可以通過輸入空格字符(空格字符可以是空白、換行和制表符)隔開。 |
| **參數** | **…** 變量 **地址表** |
| **返回值** | **int** 成功匹配和賦值的個數。如果到達文件末尾或發生讀錯誤,則返回 EOF。 |
2. 格式轉換說明符 `%[*][width][modifiers]type`
| **參數** | **描述** |
| ------------- | ------------------------------------------------------------ |
| **\*** 忽略輸入 | 這是一個可選的星號,表示數據是從流 stream 中讀取的,但是可以被忽視,即它不存儲在對應的參數中。 |
| **width** 寬度 | 這指定了在當前讀取操作中讀取的最大字符數。 |
| **modifiers** 修飾符| 為對應的附加參數所指向的數據指定一個不同于整型(針對 d、i 和 n)、無符號整型(針對 o、u 和 x)或浮點型(針對 e、f 和 g)的大小: |
| **type** 類型|指定了要被讀取的數據類型以及數據讀取方式。|
>[warning]不支持設置精度

3. 百分號輸入 `%%`
4. 字符輸入
+ 字符 `%c`
>[warning]%c只會讀取一個字符,在輸入結束時,后面不要加空白字符。
```c++
char type,confirm;
scanf("%c %c",&type,&confirm);
printf("%c,%c",type,confirm);
```
>執行情況1
>BY [回車]
>B,Y
>執行情況2
>B Y [回車]
>B,
>[success]若`scanf` 以 `%c` 開頭,最好在 `%c` 前面加入一個空格,防止程序繞過輸入,直接讀取緩沖區中的 `\n`
```c++
char type,confirm;
scanf("%c",&type);
scanf("%c",&confirm);
printf("%c,%c",type,confirm);
```
>結果
>B [回車]
>Y [回車]
>B,
>
```c++
char type,confirm;
scanf(" %c",&type);
scanf(" %c",&confirm);
printf("%c,%c",type,confirm);
```
>結果
>B [回車]
>Y [回車]
>B,Y
5. 浮點數輸入:小數形式和指數形式均可
+ 類型
+ 浮點數 `e,E,g,G,f,F`
+ 修飾符
+ 雙精度 `l`
+ 長雙精度 `L`
6. 字符串輸入 `%s`
>[primary]遇到空白字符或到達 `width` 長度(不含'\0')后字符串輸入停止。
7. 整數輸入
+ 類型
+ 十進制
+ 有符號 `d`
+ 無符號 `u`
+ 八進制
+ 無符號 `o`
+ 十六進制
+ 無符號 `x,X`
+ 修飾符
+ 短整型 `h`
+ 長整型 `l`
8. 獲取已輸入的字符數
+ 類型 `%n`
+ 修飾符
+ 短整型 `h`
長整型 `l`
## 二.格式化輸出

1. 函數概覽
| **函數** | **int** printf(**const char\*** format,...) |
| ---------- | ------------------------------------------------------------ |
| **功能** | 從標準輸入(stdout)讀取格式化輸入。若輸入緩沖區中沒有字符,則從系統隱含指定的輸入設備(鍵盤)中輸入一個字符。若輸入緩沖區中有字符,則不從緩沖區中讀取字符。 |
| **參數** | **const char** *format 格式化輸出字符串。 |
| **參數** | ... 變量表 |
| **返回值** | **int** 如果成功,則返回寫入的字符總數,否則返回一個負數。 |
2. 格式修飾符 `%[flags][width][.precision][length]specifier`
+ **flags** 標識
+ **-** 在給定的字段寬度內左對齊,**默認是右對齊**。
+ **+** 在正數前面加上+。
+ **空格** 如果沒有任何符號,則在值前面插入一個空格。
+ **#**
+ 與 o、x 或 X 說明符一起使用時,非零值前面會分別顯示 0、0x 或 0X。
+ 與 e、E 和 f 一起使用時,會強制輸出包含一個小數點,即使后邊沒有數字時也會顯示小數點。默認情況下,如果小數點后邊沒有數字時候,不會顯示顯示小數點。
+ 與 g 或 G 一起使用時,結果與使用 e 或 E 時相同,但是尾部的零不會被移除。
+ **0** 當指定width且輸出的值短于該數時,**左邊的剩余部分會填充0,而不是空格**。
+ **width** 要輸出的字符的最小數目。如果輸出的值短于該數,剩余部分會用空格填充。如果輸出的值長于該數,結果不會被截斷。
+ **.precision**
+ 對于整數說明符(d、i、o、u、x、X):precision 指定了要寫入的數字的最小位數。
+ 如果寫入的值短于該數,**結果會用零來填充**。
+ 如果寫入的值長于該數,結果不會被截斷。
+ 精度為 0 意味著不寫入任何字符。
+ 對于 e、E 和 f 說明符:要在小數點后輸出的小數位數(**會四舍五入**)。
+ 對于 g 和 G 說明符:要輸出的最大有效位數。
+ 對于 s: 要輸出的最大字符數。默認情況下,所有字符都會被輸出,直到遇到末尾的空字符。**當未指定任何精度時,默認為 1。**
+ **length**
+ h 參數被解釋為短整型或無符號短整型(僅適用于整數說明符:i、d、o、u、x 和 X)。
+ L 參數被解釋為長雙精度型(僅適用于浮點數說明符:e、E、f、g 和 G)。
+ l 參數被解釋為長整型或無符號長整型,適用于整數說明符(i、d、o、u、x 和 X)及說明符 c(表示一個寬字符)和 s(表示寬字符字符串)。
+ **specifier** 格式字符
| **格式字符** | **意義** |
| ------------ | ------------------------------------------------------------ |
| **d** | 以十進制形式輸出帶符號整數(正數不輸出符號) |
| **o** | 以八進制形式輸出無符號整數(不輸出前綴0) |
| **x,X** | 以十六進制形式輸出無符號整數(不輸出前綴0x) |
| **u** | 以十進制形式輸出無符號整數 |
| **f** | 以小數形式輸出單、雙精度實數 |
| **e,E** | 以指數形式輸出單、雙精度實數 |
| **g,G** | 以%f或%e中較短的輸出寬度輸出單、雙精度實數,且不輸出無意義的0 |
| **c** | 輸出單個字符 |
| **s** | 輸出字符串 |
| **p** | 輸出指針地址 |
- 閱讀說明
- 1.1 概述
- C++基礎
- 1.2 變量與常量
- 1.2.1 變量
- 1.2.2 字面值常量
- 字符型常量
- 數值型常量
- 1.2.3 cv限定符
- 1.3 作用域
- 1.3.1 標識符
- 1.3.2 *命名空間
- 1.3.3 作用域
- 1.3.4 可見性
- 1.4 數據類型
- 1.4.1 概述
- 1.4.2 處理類型
- 類型別名
- * auto說明符
- * decltype說明符
- 1.4.3 數組
- 1.4.4 指針
- 1.4.5 引用
- 1.5 表達式
- 1.5.1 概述
- 1.5.2 值的類別
- 1.5.3 *初始化
- 1.5.4 運算符
- 算術運算符
- 邏輯和關系運算符
- 賦值運算符
- 遞增遞減運算符
- 成員訪問運算符
- 位運算符
- 其他運算符
- 1.5.5 *常量表達式
- 1.5.6 類型轉換
- 第2章 面向過程編程
- 2.1 流程語句
- 2.1.1 條件語句
- 2.1.2 循環語句
- 2.1.3 跳轉語句
- 2.1.4 *異常處理
- 2.2 函數
- 2.2.1 概述
- 2.2.2 函數參數
- 2.2.3 內置函數
- 2.2.4 函數重載
- 2.2.5 * 匿名函數
- 2.3 存儲和生命期
- 2.3.1 生命周期與存儲區域
- 2.3.2 動態內存
- 2.4 *預處理命令
- 第3章 面向對象編程
- 3.1 概述
- 3.2 類和對象
- 3.3 成員
- 3.3.1 訪問限制
- 3.3.2 常成員
- 3.3.3 靜態成員
- 3.3.4 成員指針
- 3.3.5 this指針
- 3.4 特殊的成員函數
- 3.4.1 概述
- 3.4.2 構造函數
- 3.4.3 析構函數
- 3.4.4 拷貝語義
- 3.4.5 * 移動語義
- 3.5 友元
- 3.6 運算符重載與類型轉換
- 3.6.1 概述
- 3.6.2 重載方法
- 3.6.3 類型轉換
- 3.7 繼承與多態性
- 3.7.1 概述
- 3.7.2 派生類
- 3.7.3 子類型
- 3.7.4 虛基類
- 3.7.5 虛函數
- 3.7.6 抽象類
- 3.8 模板與泛型
- 3.8.1 概述
- 3.8.2 模板類型
- 3.8.3 *模板參數
- 3.8.4 *模板編譯
- 3.8.5 *模板推斷
- 3.8.6 *實例化與特例化
- 第4章 C++標準庫
- 4.1 概述
- 4.2 輸入輸出流
- 4.2.1 概述
- 4.2.2 *流的狀態
- 4.2.3 *常用流
- 4.2.4 *格式化I/O
- 4.2.5 *低級I/O
- 4.2.6 *隨機訪問
- 4.3 *C輸入輸出
- 4.3.1 *字符輸入輸出
- 4.3.2 *格式化輸入輸出
- 4.4 * 容器
- 4.4.1 * 概述
- 4.4.2 * 基本操作
- 4.4.3 * 順序容器
- 4.4.4 * 迭代器
- 4.4.5 * 容器適配器
- 4.5 * 泛型算法
- 4.6 * 內存管理
- 4.6.1 * 自動指針
- 4.7 * 其他設施