運行環境:VS2013
操作系統:WIN8.1
代碼是輸入水的誇脫數 輸出x誇脫數中有多少水分子
#include<stdio.h>
#include<stdlib.h>
#define G 3.344e22 //1g中水分子的數量
#define K 950 //1誇脫等於950g水分子
// 水分子數量=(x誇脫*K)*G
int main()
{
printf("請輸入水的誇脫數\n");
int x = 0;
scanf_s("%d", &x);
long double result;
result =x*K*G; //誇克數 x 950 把誇克化成克 然後 x 1g中水分子的數量
printf("水分子數量為:%G", result);//不知道此處應該用什麼合適的輸出格式符 %f試過了 沒有出錯 不過有很多無意義的0 然後我就用%g了
system("pause");
return 0;
}
請各位C前輩 幫忙看一下
1誇克中水分子的數量 程序運行的結果為
:3.1768E+025 printf中的輸出控制符為%G
:31767999999999998000000000.000000 printf中的輸出控制符為%f
用%G輸出的值 它進行了四捨五入的換算 不是准確的值
那麼 這道題中的輸出控制符 除了用%f可以 還可以用那些呢?
浮點數 有 f,e,g,E,G 的那個輸出格式
1.轉換說明符
%a(%A) 浮點數、十六進制數字和p-(P-)記數法(C99)
%c 字符
%d 有符號十進制整數
%f 浮點數(包括float和doulbe)
%e(%E) 浮點數指數輸出[e-(E-)記數法]
%g(%G) 浮點數不顯無意義的零"0"
%i 有符號十進制整數(與%d相同)
%u 無符號十進制整數
%o 八進制整數 e.g. 0123
%x(%X) 十六進制整數0f(0F) e.g. 0x1234
%p 指針
%s 字符串
%% "%"
%f 浮點數(包括float和doulbe)
%e(%E) 浮點數指數輸出[e-(E-)記數法]
%g(%G) 浮點數不顯無意義的零"0"
f,e,E,g,G格式,都是十進制浮點數格式
%a(%A) 浮點數、十六進制數字和p-(P-)記數法(C99) 是新增的 十六進制浮點數格式