1樓:匿名使用者
%d 輸出的10進位制整數,%s輸出的是字串,%f輸出的是單精度浮點數,
更多的可以看我的帖子「回c語言** vs2015:答[10]printf」:
2樓:金色潛鳥
%d 十進位制整
型。 %s 字串型。 %f float 型。 %lf double 型。
%e 浮點型指數型。%x 十六進位制專
整型。 %o 八進位制整型。%u 無符號整型。
%p 地址型。%g 簡略型屬。
在c語言中,%d,%c,%f都是什麼意思,請詳細的說一下,謝謝了
3樓:【血戮】龍桄
printf函式呼叫的一般形式 printf函式是一個標準庫函式,它的函
數原型在標頭檔案「stdio.h」中。但作為一個特例,不要求在使用 printf 函式之前必須包含stdio.
h檔案。printf函式呼叫的一般形式為: printf(「格式控制字串」,輸出表列)其中格式控制字串用於指定輸出格式。
格式控制串可由格式字串和非格式字串兩種組成。格式字串是以%開頭的字串,在%後面跟有各種格式字元,以說明輸出資料的型別、形式、長度、小數位數等。如「%d」表示按十進位制整型輸出,「%ld」表示按十進位制長整型輸出,「%c」表示按字元型輸出等。
後面將專門給予討論。 非格式字串在輸出時原樣照印,在顯示中起提示作用。 輸出表列中給出了各個輸出項, 要求格式字串和各輸出項在數量和型別上應該一一對應。
void main() a<--8,b<本例中四次輸出了a,b的值,但由於格式控制串不同,輸出的結果也不相同。第四行的輸出語句格式控制串中,兩格式串%d 之間加了一個空格(非格式字元),所以輸出的a,b值之間有一個空格。第五行的printf語句格式控制串中加入的是非格式字元逗號, 因此輸出的a,b值之間加了一個逗號。
第六行的格式串要求按字元型輸出 a,b值。第七行中為了提示輸出結果又增加了非格式字串。
二、格式字串 在turbo c中格式字串的一般形式為: [標誌][輸出最小寬度][.精度][長度]型別 其中方括號中的項為可選項。
各項的意義介紹如下: 1.型別型別字元用以表示輸出資料的型別,其格式符和意義下表所示:
表示輸出型別的格式字元 格式字元意義 d 以十進位制形式輸出帶符號整數(正數不輸出符號) o 以八進位制形式輸出無符號整數(不輸出字首o) x 以十六進位制形式輸出無符號整數(不輸出字首ox) u 以十進位制形式輸出無符號整數 f 以小數形式輸出單、雙精度實數 e 以指數形式輸出單、雙精度實數 g 以%f%e中較短的輸出寬度輸出單、雙精度實數 c 輸出單個字元 s 輸出字串 2.標誌 標誌字元為-、+、#、空格四種,其意義下表所示: 標誌格式字元 標誌意義 - 結果左對齊,右邊填空格 + 輸出符號(正號或負號)空格輸出值為正時冠以空格,為負時冠以負號 # 對c,s,d,u類無影響;對o類, 在輸出時加前 綴o 對x類,在輸出時加字首0x;對e,g,f 類當結果有小數時才給出小數點 3.
輸出最小寬度 用十進位制整數來表示輸出的最少位數。 若實際位數多於定義的寬度,則按實際位數輸出, 若實際位數少於定義的寬度則補以空格或0。 4.
精度 精度格式符以「.」開頭,後跟十進位制整數。本項的意義是:
如果輸出數字,則表示小數的位數;如果輸出的是字元, 則表示輸出字元的個數;若實際位數大於所定義的精度數,則截去超過的部分。 5.長度 長度格式符為h,l兩種,h表示按短整型量輸出,l表示按長整型量輸出。
void main() a<--15 b<--138.3576278 c<--35648256.3645687 d<--'p' main() 本例第七行中以四種格式輸出整型變數a的值,其中「%5d 」要求輸出寬度為5,而a值為15只有兩位故補三個空格。
第八行中以四種格式輸出實型量b的值。其中「%f」和「%lf 」格式的輸出相同,說明「l」符對「f」型別無影響。「%5.
4lf」指定輸出寬度為5,精度為4,由於實際長度超過5故應該按實際位數輸出,小數位數超過4位部分被截去。第九行輸出雙精度實數,「%8.4lf 」由於指定精度為4位故截去了超過4位的部分。
第十行輸出字元量d,其中「%bc 」指定輸出寬度為8故在輸出字元p之前補加7個空格。 使用printf函式時還要注意一個問題, 那就是輸出表列中的求值順序。不同的編譯系統不一定相同,可以從左到右, 也可從右到左。
turbo c是按從右到左進行的。如把例2.13改寫如下述形式:
void main() i<--8 這個程式與例2.13相比只是把多個printf語句改一個printf 語句輸出。但從結果可以看出是不同的。
為什麼結果會不同呢?就是因為printf函式對輸出表中各量求值的順序是自右至左進行 的。在式中,先對最後一項「-i--」求值,結果為-8,然後i自減1後為7。
再對「-i++」項求值得-7,然後i自增1後為8。再對「i--」項求值得8,然後i再自減1後為7。再求「i++」項得7,然後i再自增1後為8。
再求「--i」項,i先自減1後輸出,輸出值為7。 最後才求輸出表列中的第一項「++i」,此時i自增1後輸出8。但是必須注意, 求值順序雖是自右至左,但是輸出順序還是從左至右, 因此得到的結果是上述輸出結果。
字元輸出函式 putchar 函式 putchar 函式是字元輸出函式, 其功能是在顯示器上輸出單個字元。其一般形式為: putchar(字元變數) 例如:
putchar('a'); 輸出大寫字母a putchar(x); 輸出字元變數x的值 putchar('\n'); 換行 對控制字元則執行控制功能,不在螢幕上顯示。 使用本函式前必須要用檔案包含命令: #includevoid main() 資料輸入語句 c語言的資料輸入也是由函式語句完成的。
本節介紹從標準輸入裝置—鍵盤上輸入資料的函式scanf和getchar。 scanf函式 scanf函式稱為格式輸入函式,即按使用者指定的格式從鍵盤上把資料輸入到指定的變數之中。
一、scanf函式的一般形式 scanf函式是一個標準庫函式,它的函式原型在標頭檔案「stdio.h」中,與printf函式相同,c語言也允許在使用scanf函式之前不必包含stdio.h檔案。
scanf函式的一般形式為: scanf(「格式控制字串」,地址表列); 其中,格式控制字串的作用與printf函式相同,但不能顯示非格式字串, 也就是不能顯示提示字串。地址表列中給出各變數的地址。
地址是由地址運算子「&」後跟變數名組成的。例如,&a,&b分別表示變數a和變數b 的地址。這個地址就是編譯系統在記憶體中給a,b變數分配的地址。
在c語言中,使用了地址這個概念,這是與其它語言不同的。 應該把變數的值和變數的地址這兩個不同的概念區別開來。變數的地址是c編譯系統分配的,使用者不必關心具體的地址是多少。
變數的地址和變數值的關係如下: &a--->a567 a為變數名,567是變數的值,&a是變數a的地址。在賦值表示式中給變數賦值,如:
a=567 在賦值號左邊是變數名,不能寫地址,而scanf函式在本質上也是給變數賦值,但要求寫變數的地址,如&a。 這兩者在形式上是不同的。&是一個取地址運算子,&a是一個表示式,其功能是求變數的地址。
void main() 注意&的用法! 在本例中,由於scanf函式本身不能顯示提示串,故先用printf語句在螢幕上輸出提示,請使用者輸入a、b、c的值。執行scanf語句,則退出tc螢幕進入使用者螢幕等待使用者輸入。
使用者輸入7、8、9後按下回車鍵,此時,系統又將返回tc螢幕。在scanf語句的格式串中由於沒有非格式字元在「%d%d%d」之間作輸入時的間隔, 因此在輸入時要用一個以上的空格或回車鍵作為每兩個輸入數之間的間隔。 如:
7 8 9 或 7 8 9 格式字串 格式字串的一般形式為: %[*][輸入資料寬度][長度]型別 其中有方括號的項為任選項。各項的意義如下:
1.型別 表示輸入資料的型別,其格式符和意義下表所示。 格式 字元意義 d 輸入十進位制整數 o 輸入八進位制整數 x 輸入十六進位制整數 u 輸入無符號十進位制整數 f或e 輸入實型數(用小數形式或指數形式) c 輸入單個字元 s 輸入字串 2.
「*」符 用以表示該輸入項讀入後不賦予相應的變數,即跳過該輸入值。 如 scanf("%d %*d %d",&a,&b);當輸入為:1 2 3 時,把1賦予a,2被跳過,3賦予b。
3.寬度 用十進位制整數指定輸入的寬度(即字元數)。例如:
scanf("%5d",&a); 輸入: 12345678 只把12345賦予變數a,其餘部分被截去。又如:
scanf("%4d%4d",&a,&b); 輸入: 12345678將把1234賦予a,而把5678賦予b。 4.
長度 長度格式符為l和h,l表示輸入長整型資料(如%ld) 和雙精度浮點數(如%lf)。h表示輸入短整型資料。 使用scanf函式還必須注意以下幾點:
a. scanf函式中沒有精度控制,如: scanf("%5.
2f",&a); 是非法的。不能企圖用此語句輸入小數為2位的實數。 b.
scanf中要求給出變數地址,如給出變數名則會出錯。如 scanf("%d",a);是非法的,應改為scnaf("%d",&a);才是合法的。 c.
在輸入多個數值資料時,若格式控制串中沒有非格式字元作輸入資料之間的間隔則可用空格,tab或回車作間隔。c編譯在碰到空格,tab,回車或非法資料(如對「%d」輸入「12a」時,a即為非法資料)時即認為該資料結束。 d.
在輸入字元資料時,若格式控制串中無非格式字元,則認為所有輸入的字元均為有效字元。例如: scanf("%c%c%c",&a,&b,&c); 輸入為:
d e f 則把'd'賦予a, 'f'賦予b,'e'賦予c。只有當輸入為: def 時,才能把'd'賦於a,'e'賦予b,'f'賦予c。
如果在格式控制中加入空格作為間隔,如 scanf ("%c %c %c",&a,&b,&c);則輸入時各資料之間可加空格由於scanf函式"%c%c"中沒有空格,輸入m n,結果輸出只有m。 而輸入改為mn時則可輸出mn兩字元,見下面的輸入運**況:
本例表示scanf格式控制串"%c %c"之間有空格時, 輸入的資料之間可以有空格間隔。e. 如果格式控制串中有非格式字元則輸入時也要輸入該非格式字元。
例如其中用非格式符「 , 」作間隔符,故輸入時應為: 5,6,7 又如:
則輸入應為 a=5,b=6,c=7g. 如輸入的資料與輸出的型別不一致時,雖然編譯能夠通過,但結果將不正確。 void main() 由於輸入資料型別為整型, 而輸出語句的格式串中說明為長整型,因此輸出結果和輸入資料不符。
如改動程式如下: void main() 執行結果為: input a long integer 1234567890 1234567890 當輸入資料改為長整型後,輸入輸出資料相等。
誰可以詳細說明一下c語言這門課程對以後前途有多大用處啊
看你將來想做什麼,你要想搞計算機程式設計,或者你以後的工作會用到這個,那麼就相當重要。如果不是,拿就沒什麼用。另外,計算機二級對於非計算機專業的人來說是必須要的。與前途無關,必須掌握。語言是軟體設計的基礎,c語言是比較老的一款高階組合語言,不過現在仍然是世界軟專件最常用的一種 屬語言之一.不過很多軟...
c語言問題詳細解答一下謝謝C語言問題,詳細解答一下,謝謝
輸出結果是 cdeab 函式move char str,int n 的作用是把長度為n字串的尾字元,前移到串首。在main 函式中連續呼叫了n次,即把字串末尾的n個字元前移到串首。輸出結 果 cdeab 分析 只要你理解了move函式 的作用你就能明白整個過程 第一次迴圈呼叫move char st...
C語言問題解答詳細,C語言問題,詳細解答一下,謝謝
2.14e 02是2.14乘以10的2次方。c語言問題,詳細解答一下,謝謝 輸出結果是 cdeab 函式move char str,int n 的作用是把長度為n字串的尾字元,前移到串首。在main 函式中連續呼叫了n次,即把字串末尾的n個字元前移到串首。輸出結 果 cdeab 分析 只要你理解了m...