本文目錄一覽:
c語言的長整形怎麼輸入~!最好給我寫到例題,我輸入總是益出,??
長整型是可以存很大的數,但還是有限的啊,你狂輸一頓的話肯定會溢出的(呵呵)
下面是例子
#include stdio.h
void main()
{
long int a;
scanf( “%ld”, a );
printf( “%ld”, a );
}
C語言中如何輸出長整型數值
在C/C++中,64為整型一直是一種沒有確定規範的數據類型。現今主流的編譯器中,對64為整型的支持也是標準不一,形態各異。一般來說,64位整型的定義方式有long long和__int64兩種(VC還支持_int64),而輸出到標準輸出方式有printf(「%lld」,a),printf(「%I64d」,a),和cout a三種方式。
本文討論的是五種常用的C/C++編譯器對64位整型的支持,這五種編譯器分別是gcc(mingw32),g++(mingw32),gcc(linux i386),g++(linux i386),Microsoft Visual C++ 6.0。可惜的是,沒有一種定義和輸出方式組合,同時兼容這五種編譯器。為徹底弄清不同編譯器對64位整型,我寫了程序對它們進行了評測,結果如下表。
上表中,正確指編譯通過,運行完全正確;錯誤指編譯雖然通過,但運行結果有誤;無法編譯指編譯器根本不能編譯完成。觀察上表,我們可以發現以下幾點:
long long定義方式可以用於gcc/g++,不受平台限制,但不能用於VC6.0。
__int64是Win32平台編譯器64位長整型的定義方式,不能用於Linux。
「%lld」用於Linux i386平台編譯器,」%I64d」用於Win32平台編譯器。
cout只能用於C++編譯,在VC6.0中,cout不支持64位長整型。
表中最後一行輸出方式中的printint64()是我自己寫的一個函數,可以看出,它的兼容性要好於其他所有的輸出方式,它是一段這樣的代碼:
CPP
void printint64(long long a)
{
if (a=100000000)
printf(“%d\n”,a);
else
{
printf(“%d”,a/100000000);
printf(“d\n”,a0000000);
}
}
這種寫法的本質是把較大的64位整型拆分為兩個32位整型,然後依次輸出,低位的部分要補0。看似很笨的寫法,效果如何?我把它和cout輸出方式做了比較,因為它和cout都是C++支持跨平台的。首先printint64()和cout(不清空緩衝區)的運行結果是完全相同的,不會出現錯誤。我的試驗是分別用兩者輸出1000000個隨機數,實際結果是,printint64()在1.5s內跑完了程序,而cout需要2s。cout要稍慢一些,所以在輸出大量數據時,要盡量避免使用。
C語言中無符號長整型數的輸入輸出格式是什麼
C語言中無符號長整型數的輸入輸出格式%u。
示例:
intmain()
{
unsignedinta;
intb=-1;
a=b;
printf(「%u」,a);
}
擴展資料
c語言printf()輸出格式
%p指針
%s字元串
%%”%”
%a(%A)浮點數、十六進位數字和p-(P-)記數法(C99)
%c字元
%d有符號十進位整數
%f浮點數(包括float和doulbe)
%e(%E)浮點數指數輸出[e-(E-)記數法]
%g(%G)浮點數不顯無意義的零”0″
%i有符號十進位整數(與%d相同)
%o八進位整數e.g.0123
%x(%X)十六進位整數xml:namespaceprefix=st1/()e.g.0x1234
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/257803.html