用庫函數math.h 這里面的log就是數學里面ln(底數為e的那個家伙)的意思。如下代碼例子

創新互聯建站主要從事網站制作、成都網站設計、網頁設計、企業做網站、公司建網站等業務。立足成都服務久治,10年網站建設經驗,價格優惠、服務專業,歡迎來電咨詢建站服務:18980820575
#includestdio.h
#includemath.h
main()
{
double?k;
k=log(2.71828);
printf("?%f?",k);
k=log(8)/log(2);
printf("?%f?",k);
}
第一k是ln(e)的意思,e約為2.71828,屏幕上打印出值為0.999999,
第二k是求底數為2真數為8的值log2(8)=ln(8) /ln(2) (這個數學轉化式我不用多說),打印出來的結果是3.000000
#include math.h
log(x)為以2為底x的對數,可以用log(x)/log(10)表示以10為底x的對數 。
#includestdio.h
#include math.h
void main()
{
float x=5,y;
y=log(x);
printf("%f\n",y);
}
擴展資料:
C語言中使用對數函數的方法
log()函數:返回以e為底的對數值
頭文件:
1#include
log() 函數返回以 e 為底的對數值,其原型為:
1double?log?(double?x);
log()用來計算以e為底的 x 的對數值,然后將結果返回。設返回值為 ret,則
1x = eret
如果 x 為負數或 0,則會發生錯誤并設置 errno 值。錯誤代碼:
EDOM:參數x 為負數;
ERANGE:參數x
為零值,零的對數值無定義。
注意:使用 GCC 編譯時請加入-lm。
首先在C語言中要用到指數、對數的相關公式,需要引入math.h。另外ln是以e為底數,lg是以10為底數。
代碼如下:
#includestdio.h
#includemath.h
void main()
{
double exponent, base;
exponent = 3.14;
printf("ln(%f) = %.2f\n", exponent, log(exponent));//以e為底數的對數
exponent = 100;
printf("lg(%.f) = %.2f\n", exponent, log10(exponent));//以10為底數的對數
base = 5, exponent = 100;
printf("log_%.f(%.f) = %.2f\n", base, exponent, log(exponent)/log(base));//換底公式
return 0;
}
在求log_5(100)時需要用到“換底公式”:log_5(100) = ln(100)/ln(5)。
擴展資料:
math.h文件中包含的函數主要分為以下幾類:
1、三角函數、反三角函數、雙曲三角函數。
2、指數、對數。
3、取整、絕對值。
4、標準化浮點數。
涉及參數類型為double類型。
參考資料:
百度百科——換底公式
百度百科——math.h
C語言中直接提供的是e為底的自然對數log,和以10為底的常用對數log10,其他對數寫個函內數就可以。
#include stdio.h
#include math.h
double loga(double n, double base);
int main (void)
{
double a, b, c;
a = log(exp(1));
b = log10(10);
c = loga(100, 5);
printf("%lf %lf %lf", a, b, c);
}
double loga(double n, double base)
{ return log(n) / log(base);}
擴展資料:
如果一個變量名后面跟著一個有數字的中括號,這個聲明就是數組聲明。字符串也是一種數組。它們以ASCII的NULL作為數組的結束。要特別注意的是,中括號內的索引值是從0算起的。
C語言的字符串其實就是以'\0'字符結尾的char型數組,使用字符型并不需要引用庫,但是使用字符串就需要C標準庫里面的一些用于對字符串進行操作的函數。它們不同于字符數組。使用這些函數需要引用頭文件string.h。
C程序中函數的數目實際上是不限的,如果說有什么限制的話,那就是,一個C程序中必須至少有一個函數,而且其中必須有一個并且僅有一個以main為名的函數,這個函數稱為主函數,整個程序從這個主函數開始執行。
比較特別的是,比特右移()運算符可以是算術(左端補最高有效位)或是邏輯(左端補 0)位移。例如,將 11100011 右移 3 比特,算術右移后成為 11111100,邏輯右移則為 00011100。因算術比特右移較適于處理帶負號整數,所以幾乎所有的編譯器都是算術比特右移。
沒有問題,輸出m=0.301030;n=0.004321;g=69.66
編譯時會提示warning,主要原因有
1、int d=300000 過大,用長整形;
2、log()和log10()函數均是double型,double轉成float會有截斷誤差,將float r=0.01,m,n,g;
中的float改成double就不會有warning了;
3、getch()函數未聲明,頭文件加入#includeconio.h,就不會有warning了。
但warning不會影響運行結果。
c 里直接提供的是 以 e 為底的自然對數 log ,和 以 10 為底的常用對數 log10
其他對數寫個函數就可以
#include stdio.h
#include math.h
double loga(double n, double base);
int main (void)
{
double a, b, c;
a = log(exp(1));
b = log10(10);
c = loga(100, 5);
printf("%lf %lf %lf", a, b, c);
}
double loga(double n, double base)
{ return log(n) / log(base);}
分享名稱:用c語言編譯對數函數 用c語言編寫自己的對數函數
本文路徑:http://www.yijiale78.com/article2/dodohoc.html
成都網站建設公司_創新互聯,為您提供服務器托管、網站制作、云服務器、ChatGPT、微信小程序、
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯