使用程式語言進行程式設計時,需要用到各種變數來儲存各種資訊。變數保留的是它所儲存的值的記憶體位置。這意味著,當您建立乙個變數時,就會在記憶體中保留一些空間。
您可能需要儲存各種資料型別(比如字元型、寬字元型、整型、浮點型、雙浮點型、布林型等)的資訊,作業系統會根據變數的資料型別,來分配記憶體和決定在保留記憶體中儲存什麼。
c++ 為程式設計師提供了種類豐富的內建資料型別和使用者自定義的資料型別。下表列出了七種基本的 c++ 資料型別:
型別關鍵字
布林型bool
字元型char
整型char
布林型bool
字元型char
整型int
浮點型float
雙浮點型
double
無型別void
寬字元型
wchar_t
一些基本型別可以使用乙個或多個型別修飾符進行修飾:
下表顯示了各種變數型別在記憶體中儲存值時需要占用的記憶體,以及該型別的變數所能儲存的最大值和最小值。型別位
範圍char
1 個位元組
-128 到 127 或者 0 到 255
unsigned char
1 個位元組
0 到 255
signed char
1 個位元組
-128 到 127
int4 個位元組
-2147483648 到 2147483647
unsigned int
4 個位元組
0 到 4294967295
signed int
4 個位元組
-2147483648 到 2147483647
short int
2 個位元組
-32768 到 32767
unsigned short int
range
0 到 65,535
signed short int
range
-32768 到 32767
long int
4 個位元組
-2,147,483,647 到 2,147,483,647
signed long int
4 個位元組 與 long int 相同
unsigned long int
4 個位元組 0
到 4,294,967,295
float
4 個位元組
+/- 3.4e +/- 38 (~7 個數字)
double
8 個位元組
+/- 1.7e +/- 308 (~15 個數字)
long double
8 個位元組
+/- 1.7e +/- 308 (~15 個數字)
wchar_t
2 或 4 個位元組
1 個寬字元
列表內容 從上表可得知,變數的大小會根據編譯器和所使用的電腦而有所不同。 下面例項會輸出您電腦上各種資料型別的大小。
#include
using
namespace
std;
int main()
本例項使用了 endl,這將在每一行後插入乙個換行符,<< 運算子用於向螢幕傳多個值。我們也使用 sizeof() 函式來獲取各種資料型別的大小。
當上面的**被編譯和執行時,它會產生以下的結果,結果會根據所使用的計算機而有所不同:
size of char : 1您可以使用 typedef 為乙個已有的型別取乙個新的名字。下面是使用 typedef 定義乙個新型別的語法:size of short int : 2
size of long int : 4
size of double : 8
size of wchar_t : 4
typedef type newname;例如,下面的語句會告訴編譯器,feet 是 int 的另乙個名稱:
typedef int feet;現在,下面的宣告是完全合法的,它建立了乙個整型變數 distance:
feet distance;列舉型別宣告乙個可選的型別名稱和一組識別符號,用來作為該型別的值。的帶有零個或多個識別符號可以被用來作為該型別的值。每個列舉數是乙個列舉型別的常數。
建立列舉,需要使用關鍵字 enum。列舉型別的一般形式為:
enum enum-name var-list;在這裡,enum-name 是列舉型別的名稱。名稱列表 是用逗號分隔的。
例如,下面的**定義了乙個顏色列舉,變數 c 的型別為 color。最後,c 被賦值為 「blue」。
enum color c;預設情況下,第乙個名稱的值為 0,第二個名稱的值為 1,第三個名稱的值為 2,以此類推。但是,您也可以給名稱賦予乙個特殊的值,只需要新增乙個初始值即可。例如,在下面的列舉中,green 的值為 5。c = blue;
enum color ;在這裡,blue 的值為 6,因為預設情況下,每個名稱都會比它前面乙個名稱大 1。
C 01 基本資料型別和指標入門
i位址的佔位符為p 基本資料型別 int main 列印結果 i 的值是 100 d 的值是 200.000000 f 的值是 200.000000 l 的值是 100 s 的值是 100 c 的值是 dint main int main 通過 例如 i 獲取位址的值 乙個指標的大小始終是32位系統...
C 0 1揹包問題
0 1揹包問題 0 1揹包問題基本思想 p i,j 表示在前面i個物品總價值為j時的價值最大值。str i,j 表示在前面i個物品總價值為j時的價值最大值時的物品重量串。i 0 或者j 0時 p i,j 0 str i,j 第i件物品的在重量小於j時能夠放入揹包 p i,j p i 1,j w i ...
C 01揹包問題
01揹包問題 有n個重量和價值分別為wi,vi的物品。從這些物品中挑選出總重量不超過w的物品,求所有挑選方案中價值總和的最大值 輸入格式 nw v w輸出格式 價值總和最大值 輸入 42 3 1 23 4 2 25 輸出 7解題思路 對每個物品有兩種選擇,選或者不選。選擇該物品的話,總價值會增加,剩...