關於c語言的問題,一個關於c語言的問題

時間 2021-09-05 20:05:54

1樓:彬彬有禮

對於你的疑問,我一個一個幫你解決:

1.因為5/9:代表整除取商,即結果為0;

而 5.0/9:代表5除以9,即結果為0.555556;

所以兩者結果完全不一樣。

再比如:3/2=1,而3.0/2=1.5

2.double b=2這是對的,沒有必要寫成double b=2.0,因為系統會自動幫你轉為對應的形式。

3.double a=3.14159f 好像沒有這種寫法,而且這種寫法也不怎麼簡潔,使人明白;

如果要寫,可以這樣表達:

double a=3.14159;

(float)a

這裡的(float)a代表將double型的a強制轉換為float型,這樣就達到了目的。

2樓:科技程式迷

1、不建議將5.0寫成5,因為c是單精度浮點型,int型變數會向精度高的單精度float型變數轉化,這樣是為了保證資料的準確性可靠性,5.0是單精度浮點型,5是整型,不一樣的,5.

0/9是單精度結果0.555556,而5/9是整型結果為0。

2、沒錯,在宣告變數的語句後面直接用賦值語句給變數初始化變數值。float a=2系統會自動將2轉化為單精度。輸入一個值給變數就不能用「double b=2,或float a=2;」而是用scanf函式來輸入,比如要輸入兩個數值分別給單精度a和單精度b,**是scanf("%f%f",&a,&b);

3、float a=3.14159l在這裡是可以的,雖然在這裡精度不會損失,但是l說明資料是long double。double a=3.

14159f也沒問題的,3.14159f單精度向精度更高的雙精度轉換。

3樓:南雨筠

1、不能,如果寫成5的話,那麼5/9的結果為int型,即為0,寫成5.0則會進行自動型別轉換,結果為實型。

2、是對的,這表示在變數宣告的同時進行賦初值,可以進行這樣輸入,這樣的結果會自動將2轉換成宣告的型別。

3、如果寫成float a=3.14159l ,編譯器會給出警告,因為從高型別向低型別轉換會影響精度,

double a=3.14159f是可以的,由低型別可自動向高型別轉換。

關於c語言的一個問題

4樓:

你不覺得你每個for迴圈中都加上;i<=max-1||i

5樓:匿名使用者

燙說明少了字串結束標識'\0'

一個關於c語言的問題!求高手解答

6樓:匿名使用者

#include

int main( void )

一、注意書寫格式,不然不好檢查錯誤。

二、c中不支援全形資訊,所有的標點符號全要用英文字元。

7樓:

inty=-23456;

int和y之間沒加空格,不知道你的問題是不是這裡!

8樓:

#include

int main()

這樣試試

9樓:半季流年

可能是你資料的計算結果超出了整型變數的表示範圍!!

對於int型變數,不同的編譯器為其分配的記憶體大小都不同,我的意思是說雖然記憶體是由系統分配,但卻是由編譯器申請大小的。有的編譯器會申請分配2個位元組,比如tc,而有的會申請4個位元組大小,比如vc6.0。

所以在不同的編譯器裡編譯,int型變數的表示範圍也不同,如果為其申請2個位元組,那它表示的範圍就是-2^15~2^15-1,也就是-32768~32767;如果是4個位元組,那範圍就是-2^31~2^31-1。你試試在vc下編譯執行,這個程式的輸出就正確了!

請教一個關於c語言的問題、

10樓:夏雨天兒星星

#include

#include

void main()

上面是int,如果是需要double,float等等的話可以手動輸入用scanf,sizeof知道他們的位元組數就ok了。

一個關於c語言的問題,求教!!

11樓:冰雨vs冰霜

a=b 是賦值;

a==b 是等號;

這是新手長犯錯誤

c語言中經常犯的毛病!!初學者必看!!!

c 語言的最大特點是:功能強、使用方便靈活。c編譯的程式對語法檢查並不象其它高階語言那麼嚴格,這就給程式設計人員留下「靈活的餘地」,但還是由於這個靈活給程式的除錯帶來了許多不便,尤其對初學c語言的人來說,經常會出一些連自己都不知道錯在**的錯誤。

看著有錯的程式,不知該如何改起,本人通過對c的學習,積累了一些c程式設計時常犯的錯誤,寫給各位學員以供參考。

1.書寫識別符號時,忽略了大小寫字母的區別。

main()

編譯程式把a和a認為是兩個不同的變數名,而顯示出錯資訊。c認為大寫字母和小寫字母是兩個不同的字元。習慣上,符號常量名用大寫,變數名用小寫表示,以增加可讀性。

2.忽略了變數的型別,進行了不合法的運算。

main()

%是求餘運算,得到a/b的整餘數。整型變數a和b可以進行求餘運算,而實型變數則不允許進行「求餘」運算。

3.將字元常量與字串常量混淆。

char c;

c="a";

在這裡就混淆了字元常量與字串常量,字元常量是由一對單引號括起來的單個字元,字串常量是一對雙引號括起來的字元序列。c規定以「\」作字串結束標誌,它是由系統自動加上的,所以字串「a」實際上包含兩個字元:『a'和『\',而把它賦給一個字元變數是不行的。

4.忽略了「=」與「==」的區別。

在許多高階語言中,用「=」符號作為關係運算子「等於」。如在basic程式中可以寫

if (a=3) then …

但c語言中,「=」是賦值運算子,「==」是關係運算子。如:

if (a==3) a=b;

前者是進行比較,a是否和3相等,後者表示如果a和3相等,把b值賦給a。由於習慣問題,初學者往往會犯這樣的錯誤。

5.忘記加分號。

分號是c語句中不可缺少的一部分,語句末尾必須有分號。

a=1b=2

編譯時,編譯程式在「a=1」後面沒發現分號,就把下一行「b=2」也作為上一行語句的一部分,這就會出現語法錯誤。改錯時,有時在被指出有錯的一行中未發現錯誤,就需要看一下上一行是否漏掉了分號。

對於複合語句來說,最後一個語句中最後的分號不能忽略不寫(這是和pascal不同的)。

6.多加分號。

對於一個複合語句,如:

;複合語句的花括號後不應再加分號,否則將會畫蛇添足。

又如:if (a%3==0);

i++;

本是如果3整除a,則i加1。但由於if (a%3==0)後多加了分號,則if語句到此結束,程式將執行i++語句,不論3是否整除a,i都將自動加1。

再如:for (i=0;i<5;i++);

本意是先後輸入5個數,每輸入一個數後再將它輸出。由於for()後多加了一個分號,使迴圈體變為空語句,此時只能輸入一個數並輸出它。

7.輸入變數時忘記加地址運算子「&」。

int a,b;

scanf("%d%d",a,b);

這是不合法的。scanf函式的作用是:按照a、b在記憶體的地址將a、b的值存進去。「&a」指a在記憶體中的地址。

8.輸入資料的方式與要求不符。①scanf("%d%d",&a,&b);

輸入時,不能用逗號作兩個資料間的分隔符,如下面輸入不合法:

3,4輸入資料時,在兩個資料之間以一個或多個空格間隔,也可用回車鍵,跳格鍵tab。

②scanf("%d,%d",&a,&b);

c規定:如果在「格式控制」字串中除了格式說明以外還有其它字元,則在輸入資料時應輸入與這些字元相同的字元。下面輸入是合法的:

3,4此時不用逗號而用空格或其它字元是不對的。

3 4 3:4

又如:scanf("a=%d,b=%d",&a,&b);

輸入應如以下形式:

a=3,b=4

9.輸入字元的格式與要求不一致。

在用「%c」格式輸入字元時,「空格字元」和「轉義字元」都作為有效字元輸入。

scanf("%c%c%c",&c1,&c2,&c3);

如輸入a b c

字元「a」送給c1,字元「 」送給c2,字元「b」送給c3,因為%c只要求讀入一個字元,後面不需要用空格作為兩個字元的間隔。

10.輸入輸出的資料型別與所用格式說明符不一致。

例如,a已定義為整型,b定義為實型

a=3;b=4.5;

printf("%f%d\n",a,b);

編譯時不給出出錯資訊,但執行結果將與原意不符。這種錯誤尤其需要注意。

11.輸入資料時,企圖規定精度。

scanf("%7.2f",&a);

這樣做是不合法的,輸入資料時不能規定精度。

12.switch語句中漏寫break語句。

例如:根據考試成績的等級列印出百分制數段。

switch(grade)

printf("%d",a);

}(2)main()

while(i<=10);

printf("%d",a);

}可以看到,當輸入i的值小於或等於10時,二者得到的結果相同。而當i>10時,二者結果就不同了。因為while迴圈是先判斷後執行,而do- while迴圈是先執行後判斷。

對於大於10的數while迴圈一次也不執行迴圈體,而do-while語句則要執行一次迴圈體。

14.定義陣列時誤用變數。

int n;

scanf("%d",&n);

int a[n];

陣列名後用方括號括起來的是常量表示式,可以包括常量和符號常量。即c不允許對陣列的大小作動態定義。

15.在定義陣列時,將定義的「元素個數」誤認為是可使的最大下標值。

main()

;printf("%d",a[10]);

}c語言規定:定義時用a[10],表示a陣列有10個元素。其下標值由0開始,所以陣列元素a[10]是不存在的。

16.在不應加地址運算子&的位置加了地址運算子。

scanf("%s",&str);

c語言編譯系統對陣列名的處理是:陣列名代表該陣列的起始地址,且scanf函式中的輸入項是字元陣列名,不必要再加地址符&。應改為:

scanf("%s",str);

17.同時定義了形參和函式中的區域性變數。

int max(x,y)

int x,y,z;

形參應該在函式體外定義,而區域性變數應該在函式體內定義。應改為:

int max(x,y)

int x,y;

{int z;

z=x>y?x:y;

return(z);

12樓:

a=b 是賦值;

a==b 才能表示a,b相等;

另外那個 if() 後面只有一條語句, 可以不要的。。

關於C語言的一個問題,關於C語言的6個問題

值的互換不一定需要中間變數。但你所說的交換記憶體地址的話,不通過中間變數挺難做得到。因為c語言沒有直接交換的語句。所以,可以通過以下方式來進行值交換。void swap int a,int b void main 雖然n和m的值是互相交換了,但是它們的各自的指標地址並沒有改變。當然要有中間變數了。你...

關於C語言的問題,求教,一個關於C語言的問題,求教!!

冰雨vs冰霜 a b 是賦值 a b 是等號 這是新手長犯錯誤 c語言中經常犯的毛病!初學者必看!c 語言的最大特點是 功能強 使用方便靈活。c編譯的程式對語法檢查並不象其它高階語言那麼嚴格,這就給程式設計人員留下 靈活的餘地 但還是由於這個靈活給程式的除錯帶來了許多不便,尤其對初學c語言的人來說,...

關於C語言的細節問題,關於C語言的一個細節問題

不用每次都開闢記憶體空間,存放b c的值,編譯器可以做到將b c的結果存放在暫存器中,這樣既方便又高效。a 編譯器不可能把前者優化為後者,因為那樣做編譯的結果可能是錯誤的。 可能會快一點,但快不了多少,因為cpu運算是把資料從記憶體 或硬碟 取到暫存器裡,再運算的。執行a b c時並不會在記憶體中開...