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語言沒有直接交換的語句。所以,可以通過以下方式來進行值交換。void swap int a,int b void main 雖然n和m的值是互相交換了,但是它們的各自的指標地址並沒有改變。當然要有中間變數了。你... 冰雨vs冰霜 a b 是賦值 a b 是等號 這是新手長犯錯誤 c語言中經常犯的毛病!初學者必看!c 語言的最大特點是 功能強 使用方便靈活。c編譯的程式對語法檢查並不象其它高階語言那麼嚴格,這就給程式設計人員留下 靈活的餘地 但還是由於這個靈活給程式的除錯帶來了許多不便,尤其對初學c語言的人來說,... 不用每次都開闢記憶體空間,存放b c的值,編譯器可以做到將b c的結果存放在暫存器中,這樣既方便又高效。a 編譯器不可能把前者優化為後者,因為那樣做編譯的結果可能是錯誤的。 可能會快一點,但快不了多少,因為cpu運算是把資料從記憶體 或硬碟 取到暫存器裡,再運算的。執行a b c時並不會在記憶體中開...關於C語言的一個問題,關於C語言的6個問題
關於C語言的問題,求教,一個關於C語言的問題,求教!!
關於C語言的細節問題,關於C語言的一個細節問題