當前位置:首頁 » 編程語言 » c語言雙精度如何轉化成整型
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

c語言雙精度如何轉化成整型

發布時間: 2023-02-10 17:18:37

1. c語言有沒有函數可以直接把數字字元串轉換整型或浮點型的

#include
double
atof(
const
char
*str
);
功能:將字元串str轉換成一個雙精度數值並返回結果。
參數str
必須以有效數字開頭,但是允許以「e」或「e」除外的任意非數字字元結尾。例如:
x
=
atof(
"42.0is_the_answer"
);
x的值為42.0.
#include
int
atoi(
const
char
*str
);
功能:將字元串str轉換成一個整數並返回結果。參數str
以數字開頭,當函數從str
中讀到非數字字元則結束轉換並將結果返回。例如,
i
=
atoi(
"512.035"
);
i
的值為
512.

2. c語言中如何將字元串轉化成整數型並輸出

在C語言中將字元串轉化成整型有兩種方法。


1 用atoi函數。
atoi的功能就是將字元串轉為整型並返回。其聲明為


int atoi(char *str);


比如atoi("1234");會返回整型1234。

2 用sscanf。


sscanf與標准格式化輸入函數scanf類似,不過源並非是標准輸入,而是字元串。


用sscanf可以處理更復雜的字元串。


比如字元串char * str = "a=1, b=2";


定義int a,b;後


可以用


sscanf(str,"a=%d, b=%d",&a,&b);


來將a,b值提取,計算後,a=1, b=2。

3. C語言中整型,字元型,浮點型,和雙精度浮點型,詳解

整型,計算機中的一個基本的專業術語,指沒有小數部分的數據。整型可以用十進制,十六進制或八進制符號指定,前面可以加上可選的符號(- 或者 +)。包括整型常量和整型變數,整型變數又包括短整型、基本整型、長整型,它們都分為有符號和無符號兩種版本,是一種智能的計算方式。

字元型量包括字元常量和字元變數。字元串常量由一對雙引號括起的字元序列。字元變數的取值是字元常量,即單個字元。字元變數的類型說明符是char。字元變數類型說明的格式和書寫規則都與整型變數相同。

浮點型利用指數使小數點的位置可以根據需要而上下浮動,從而可以靈活地表達更大范圍的實數。

雙精度浮點型,此數據類型與單精度數據類型(float)相似,但精確度比float高,編譯時所佔的內存空間依不同的編譯器而有所不同,是double float數據類型,C/C++中表示實型變數的一種變數類型。



(3)c語言雙精度如何轉化成整型擴展閱讀

雙精度浮點型類型數值可轉換到其他類型的整數或浮點數,反之亦然。雙精度浮點型常量的最後一個字元可加上「d」或「D」。其存儲格式與浮點型類似,最高位為符號位,次高11位為指數位,其次52位為尾數。

雙精度型就是雙精度浮點型,同數值型比,它能提供更高的數值精度,採用固定存儲長度的浮點數形式,每個雙精度浮點型數據佔8個位元組。與數值型數據不同,它的小數點位置是由輸入的數據值來決定的,並且只能用於表中的欄位。

4. C語言數據類型的轉換

讓我來說說這個問題吧。
一.自動轉換
自動轉換遵循以下規則:
1) 若參與運算量的類型不同,則先轉換成同一類型,然後進行運算。
2) 轉換按數據長度增加的方向進行,以保證精度不降低。如int型和long型運算時,先把int量轉成long型後再進行運算。
a.若兩種類型的位元組數不同,轉換成位元組數高的類型
b.若兩種類型的位元組數相同,且一種有符號,一種無符號,則轉換成無符號類型
3)所有的浮點運算都是以雙精度進行的,即使僅含float單精度量運算的表達式,也要先轉換成double型,再作運算。
4)char型和short型參與運算時,必須先轉換成int型。
5)在賦值運算中,賦值號兩邊量的數據類型不同時,賦值號右邊量的類型將轉換為左邊量的類型。如果右邊量的數據類型長度左邊長時,將丟失一部分數據,這樣會降低精度,丟失的部分按四捨五入向前舍入。
二.隱式轉換
隱式類型轉換分三種,即算術轉換、賦值轉換和輸出轉換。
1.算術轉換
進行算術運算(加、減、乘、除、取余以及符號運算)時,不同類型數招必須轉換成同一類型的數據才能運算,算術轉換原則為:
在進行運算時,以表達式中最長類型為主,將其他類型位據均轉換成該類型,如:
(1)若運算數中有double型或float型,則其他類型數據均轉換成double類型進行運算。
(2)若運算數中最長的類型為long型.則其他類型數均轉換成long型數。
(3)若運算數中最長類型為int型,則char型也轉換成int型進行運算。算術轉換是在運算過程中自動完成的。
2.賦值轉換
進行賦值操作時,賦值運算符右邊的數據類型必須轉換成賦值號左邊的類型,若右邊的數據類型的長度大於左邊,則要進行截斷或舍入操作。
下面用一實例說明:
char ch;
int i,result;
float f;
double d;
result=ch/i+(f*d-i);
(1)首先計算 ch/i,ch → int型,ch/i → int型。
(2)接著計算 f*d-i,由於最長型為double型,故f→double型,i→double型,f*d-i→double型。
(3)(ch/i) 和(f*d-i)進行加運算,由於f*d-i為double型,故ch/i→double型,ch/i+(f*d-i)→double型。
(4)由於result為int型,故ch/i+(f*d-i)→double→int,即進行截斷與舍入,最後取值為整型。
3.輸出轉換
在程序中將數據用printf函數以指定格式輸出時,當要輸出的鹽據類型與輸出格式不符時,便自動進行類型轉換,如一個long型數據用整型格式(%d)輸出時,則相當於將long型轉換成整型(int)數據輸出;一個字元(char)型數據用整型格式輸出時,相當於將char型轉換成int型輸出。
注意:較長型數據轉換成短型數據輸出時,其值不能超出短型數據允許的值范圍,否則轉換時將出錯。如:
long a=80000;
printf("%d",a);
運行結果為14464,因為int型允許的最大值為32767,80000超出此值,故結果取以32768為模的余數,即進行如下取余運算:
(80000-32768)-32768=14464;
輸出的數據類型與輸出格式不符時常常發生錯誤,如:
int d=9;
printf("%f",d);

float c=3.2;
printf("%d",c);
將產生錯誤的結果。
同一句語句或表達式如果使用了多種類型的變數和常量(類型混用),C 會自動把它們轉換成同一種類型。以下是自動類型轉換的基本規則:
1. 在表達式中,char 和 short 類型的值,無論有符號還是無符號,都會自動轉換成 int 或者 unsigned int(如果 short 的大小和 int 一樣,unsigned short 的表示範圍就大於 int,在這種情況下,unsigned short 被轉換成 unsigned int)。因為它們被轉換成表示範圍更大的類型,故而把這種轉換稱為「升級(promotion)」。
2. 按照從高到低的順序給各種數據類型分等級,依次為:long double, double, float, unsigned long long, long long, unsigned long, long, unsigned int 和 int。這里有一個小小的例外,如果 long 和 int 大小相同,則 unsigned int 的等級應位於 long 之上。char 和 short 並沒有出現於這個等級列表,是因為它們應該已經被升級成了 int 或者 unsigned int。
3. 在任何涉及兩種數據類型的操作中,它們之間等級較低的類型會被轉換成等級較高的類型。
4. 在賦值語句中,= 右邊的值在賦予 = 左邊的變數之前,首先要將右邊的值的數據類型轉換成左邊變數的類型。也就是說,左邊變數是什麼數據類型,右邊的值就要轉換成什麼數據類型的值。這個過程可能導致右邊的值的類型升級,也可能導致其類型降級(demotion)。所謂「降級」,是指等級較高的類型被轉換成等級較低的類型。
5. 作為參數傳遞給函數時,char 和 short 會被轉換成 int,float 會被轉換成 double。使用函數原型可以避免這種自動升級。
三.強制轉換
強制類型轉換是通過類型轉換運算來實現的。其一般形式為:(類型說明符)(表達式)其功能是把表達式的運算結果強制轉換成類型說明符所表示的類型。自動轉換是在源類型和目標類型兼容以及目標類型廣於源類型時發生一個類型到另一類的轉換。例如: (float) a 把a轉換為實型,(int)(x+y) 把x+y的結果轉換為整型。在使用強制轉換時應注意以下問題:

1.類型說明符和表達式都必須加括弧(單個變數可以不加括弧),如把(int)(x+y)寫成(int)x+y則成了把x轉換成int型之後再與y相加了。

2.無論是強制轉換或是自動轉換,都只是為了本次運算的需要而對變數的數據長度進行的臨時性轉換,而不改變數據說明時對該變數定義的類型。

例1:

main()

{

float f=5.75;

printf("(int)f=%d,f=%f\n",(int)f,f);

}

f<--5.75

將float f強制轉換成int f float f=5.75;printf("(int)f=%d,f=%f\n",(int)f,f); 本例表明,f雖強制轉為int型,但只在運算中起作用, 是臨時的,而f本身的類型並不改變。因此,(int)f的值為 5(刪去了小數)而f的值仍為5.75。

5. c語言中如何將字元串轉化成整數型並輸出

c語言中,可以使用atoi()函數將字元串轉化成整數型並輸出。

atoi (表示 ascii to integer)是把字元串轉換成整型數的一個函數,應用在計算機程序和辦公軟體中。int atoi(const char *nptr) 函數會掃描參數 nptr字元串,會跳過前面的空白字元(例如空格,tab縮進)等。

如果 nptr不能轉換成 int 或者 nptr為空字元串,那麼將返回 0 。特別注意,該函數要求被轉換的字元串是按十進制數理解的。atoi輸入的字元串對應數字存在大小限制(與int類型大小有關),若其過大可能報錯-1。

(5)c語言雙精度如何轉化成整型擴展閱讀:

C語言常用函數:

1、int abs(int i)

返回整型參數i的絕對值。

2、double cabs(struct complex znum)

返回復數znum的絕對值。

3、double fabs(double x)

返回雙精度參數x的絕對值。

4、long labs(long n)

返回長整型參數n的絕對值。

5、double exp(double x)

返回指數函數ex的值。

6、double frexp(double value,int *eptr)

返回value=x*2n中x的值,n存貯在eptr中。

7、double ldexp(double value,int exp)

返回value*2exp的值。

8、double log(double x)

返回logex的值。

9、double log10(double x)

返回log10x的值。

10、double pow(double x,double y)

返回x^y的值。

6. 求大佬幫我解釋一下 C語言里 單精度實型常量和雙精度實型常量是怎麼轉化成整形常量的

調用printf函數,必須對應格式符中的類型,你printf輸出的是%d整形值,而參數值又是float類型,這就是問題所在,必須類型對應,把代碼改成如下即可:
printf("%d",(int)a); //a強制轉換成int類型

7. C語言用DOUBLE輸出的是雙精度,怎樣把它轉成整型-_-

強制類型轉換,語法是:
(希望的轉換後的類型) var // 比如將double的變數var轉換為int, (int)var

前面的轉換只會保留小數點前面的值,如果需要實現「四捨五入」,你要自己處理一下。