日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

UVA10341解方程(二分)

發布時間:2025/6/17 编程问答 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 UVA10341解方程(二分) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
題意:
? ? ? 給你一個方程 F[x] = pe^-x + qsin(x) + rcos(x) + stan(x) + tx^2 + u = 0(0<=p,r<=20,-20<=q,s,t<=0),給你pqrstu然后問你在定義域內的解是多少0<=x<=1。


思路:
? ? ? 在定義域內,前面5個都是減函數,所以當F[0] >= 0 && F[1] <= 0時才有唯一解,否則無解,如果有解的話既然是單調的,那么我們就可以二分去求解,二分的時候一開始根據絕對值的大小判斷一直得不出答案,最后按照函數小于零的時候就往左移才過。




#include<math.h>
#include<stdio.h>


#define eps 0.0000000001
double p ,q ,r ,s ,t ,u;


double Fun(double x)
{
? ? return p*exp(-x) + q*sin(x) + r*cos(x) + s * tan(x) + t * x * x + u;
}


double abss(double x)
{
? ? return x > 0 ? x : -x;
}


int main ()
{
? ? while(~scanf("%lf %lf %lf %lf %lf %lf" ,&p ,&q ,&r ,&s ,&t ,&u))
? ? {
? ? ? ? if(Fun(0) < -eps || Fun(1) > eps)
? ? ? ? {
? ? ? ? ? ? printf("No solution\n");
? ? ? ? ? ? continue;
? ? ? ? }
? ? ? ? double low ,up ,mid;
? ? ? ? low = 0 ,up = 1;
? ? ? ? for(int i = 1 ;i <= 50 ;i ++)
? ? ? ? {
? ? ? ? ? ? mid = low + (up - low) / 2;
? ? ? ? ? ? if(Fun(mid) < 0) up = mid;
? ? ? ? ? ? else low = mid;
? ? ? ? }
? ? ? ? printf("%.4lf\n" ,low);
? ? }


}









總結

以上是生活随笔為你收集整理的UVA10341解方程(二分)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。