weinan030416

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

二分查找

三次方根

直接写

复制代码
#include<iostream>
#include<cmath>
#include<iomanip>
using namespace std;

double n;

int main()
{
    bool sign;
    cin>>n;
    double l=-10000,r=10000;
    while(r-l>=1e-8)
    {
        double mid=(l+r)/2;
        if(mid*mid*mid>=n)
        r=mid;
        else
        l=mid;
    }
    cout<<setiosflags(ios::fixed)<<setprecision(6)<<l;
    return 0;
}
复制代码

函数有错需要改

复制代码
#include<iostream>
#include<cmath>
#include<iomanip>
using namespace std;

double n;
double dfs(int l,int r,int n)
{
    double mid=(l+r)/2;
    if(r-l<1e-1)
    return mid;
    else
    {
        if(mid*mid*mid>=n)
        return dfs(l,mid,n);
        else
        return dfs(mid,r,n);
    }    
}

int main()
{
    cin>>n;
    double l=-10000,r=10000;
    cout<<setiosflags(ios::fixed)<<setprecision(6)<<dfs(l,r,n);
    return 0;
}
复制代码

 找对应数字

复制代码
#include<iostream>
using namespace std;
int num[100000],target,t,n;

int find(int begin,int end,int target)
{
    
    while(begin<end)
    {
        int mid=(begin+end)/2;
        if(num[mid]>=target)
        {
            end=mid;
        }
        else
        {
            begin=mid+1;
        }
    }
    if(num[end]==target)
    return end;
    else
    return -1;
}

int main()
{
    ios::sync_with_stdio(false);
    cin>>n;
    for(int i=0;i<n;i++)
    {
        cin>>num[i];
    }
    cin>>t;
    for(int i=0;i<t;i++)
    {
        cin>>target;
        cout<<find(0,n-1,target)<<endl;
    }
    return 0;
}
复制代码

 

posted on   楠030416  阅读(18)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】
点击右上角即可分享
微信分享提示