當前位置:首頁 » 編程語言 » c語言輸出ind00
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

c語言輸出ind00

發布時間: 2022-10-25 23:23:25

A. c語言輸出了 -1.#IND00是什麼意思

凡是出現-1.#IND00.基本可以肯定是發生了除0錯誤。

你這復雜的計算,看的人眼暈,自己加些調試語句查一下吧

B. C語言問題,結果出現IND00

我不太明白你的題,但是可以給你一些意見,

這個公式是有最值的吧,建議你將這個公式計算的代碼封裝到一個函數里,比如是double sin(int n) ret1=sin(n); ret2 = sin(n), 然後就簡單了,在循環里這么寫 while(ret2 - ret1 < 1e-16)n++;

這樣就好了

C. C語言輸出了 -1.#IND00.-1.#IND00 這是什麼意思

凡是出現-1.#IND00.基本可以肯定是發生了除0錯誤。
比如k1=-1*(x2-x1)/(y2-y1);
k2=-1*(x4-x3)/(y4-y3);
e=(d-b+k1*a-k2*c)/(k1-k2);
f=(k1*k2*(c-a)+k2*b-k1*d)/(k2-k1);
都可能發生。

D. 一個簡單的c語言程序,輸出-1.#IND00..不知道哪裡錯

進行浮點數編程時,如果沒有注意,常常會出現輸出類似 1.#IND, 1.#INF 或者 nan, inf 之類奇怪的輸出。這通常隱含了浮點數操作的異常。

特殊浮點數的含義

1.#INF / inf:這個值表示「無窮大 (infinity 的縮寫)」,即超出了計算機可以表示的浮點數的最大范圍(或者說超過了 double 類型的最大值)。例如,當用 0 除一個整數時便會得到一個1.#INF / inf值;相應的,如果用 0 除一個負整數也會得到 -1.#INF / -inf 值。

-1.#IND / nan:這個的情況更復雜,一般來說,它們來自於任何未定義結果(非法)的浮點數運算。"IND"是 indeterminate 的縮寫,而"nan"是 not a number 的縮寫。產生這個值的常見例子有:對負數開平方,對負數取對數,0.0/0.0,0.0*∞, ∞/∞ 等。

簡而言之,如果遇到 1.#INF / inf,就檢查是否發生了運算結果溢出除零,而遇到 1.#IND / nan,就檢查是否發生了非法的運算。

特殊浮點數的判斷

很多 C 庫都提供了一組函數用來判斷一個浮點數是否是無窮大或 NaN。int _isnan(double x) 函數用來判斷一個浮點數是否是 NaN,而 int _finite(double x) 用以判斷一個浮點數是否是無窮大。

你可能已經注意到了,上面兩個函數都是以下劃線開頭的,因此在可移植性上可能是存在問題的,那麼如何實現一個通用的判斷版本呢?首先,對於 Nan,可以用下面的代碼實現:

bool IsNumber(double x)
{
// 這里的比較操作看上去總是會得到 true
// 但有趣的是對於 IEEE 754 浮點數 NaN 來說總會得到 false!
return (x == x);
}
而下面的代碼可以判斷一個浮點數是否是有限的(finite, 即既不是 NaN 又不是 infinite):

bool IsFiniteNumber(double x)
{
return (x <= DBL_MAX && x >= -DBL_MAX);
}
其中,DBL_MAX 是 <float.h> 中預定義的常量。

把上面兩個函數結合起來,還可以實現一個浮點數是否是 Inf 的判斷。

E. C語言中出現1.#IND00如何解決

(1/(l*c)-pow(r,2)/(4*pow(c,2)))
我試驗了幾個數字,結果為負值,不能開sqrt,所以結果是
輸出後頻率就一直=-1.#IND00
不知道原來公式是什麼,發出來,修改一下,應該可以了
printf("=%lf==\n",(1/(l*c)-pow(r,2)/(4*pow(c,2))));看看結果