24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 2043  |  回复: 8
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

renchong

兑换贵宾

优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!

[求助] 一个区间搜索的c语言程序 出问题了

我写了个搜索 大-小-大 区间的程序 ,但最后运行结果始终是错的,不清楚哪里有问题(演算过 逻辑上是正确的)求虫友们帮帮忙
#include
main()
{
int a,b,x0,x1,x2,h,f0,f1,f2;
printf("please input the number\n";
scanf("x0=%d,h=%d",&x0,&h);
x1=x0+h;
f1=f(x1);
f0=f(x0);
if(f1     {
    h=2*h;
    x2=x0+h;
    f2=f(x2);
    for(f1,f2;f2         {
            x0=x1;
            x1=x2;
            x2=x1+h;
            f0=f(x0);
            f1=f(x1);
            f2=f(x2);
        }
    a=x0;
    b=x2;
    }
else
    {
    h=-h;
    x2=x0+h;
    f2=f(x2);
    for(f0,f2;f2         {
            x1=x0;
            x0=x2;
            x2=x0+h;
            f0=f(x0);
            f1=f(x1);
            f2=f(x2);
        }
    a=x2;
    b=x1;
    }
printf("a=%d,b=%d\n",a,b);
getch();
}
int f(int n)
{
return 2+n^2;
}
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

renchong

超级版主

优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!

送鲜花一朵
引用回帖:
: Originally posted by xqhuang8793 at 2011-12-16 15:15:06:
楼主,你的程序有几个小问题,给你稍微改了下,仅供参考,测试几个例子,已通过。
#include<stdio.h>

int f(int n)
{
        return 2 + n * n;
}

int main()
{
        int a, b, x0, x1, x2, h, f0, f1, f ...

非常感谢  本来想送BB的 但是没找到送的地方 一朵花 聊表感谢哈
8楼2011-12-16 16:27:33
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 9 个回答

微尘、梦想

兑换贵宾

优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!

【答案】应助回帖

感谢参与,应助指数 +1
什么是大小大区间的程序呀,没明白是什么意思,能解释点清楚么,你的代码实在太难看了~
任风云变幻,我笑对人生!
2楼2011-12-15 20:22:00
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wangyuewu08

实习版主

优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!

【答案】应助回帖


感谢参与,应助指数 +1
jjdg(金币+1): 感谢支持 2011-12-16 01:14:03
我曾经编过类似的程序,大 - 小 - 大区间是用来确定凹函数的极值区间的,这段程序是用来求解凹函数的极值区间并求极值的吧,我直接站过来吧
CODE:
/****************************************************************
*        名称 :        确定搜索区间的外推法                                      *
*        说明 :        假设函数f( x )具有单谷性,即在所考虑的区间内部,          *
*                          函数f( x )有唯一的极小点x0。为了确定极小点x所在           *
*                          的区间,应使函数f( x )在[ a, b ]区间内形成                *
*                          “高-低-高”趋势。                                        *
*        作者 :        ***                                                                                                *
*        日期 :        2011-05-22                                                                                         *
****************************************************************/
#include

/****************************************************
*        函数声明                                                            *
****************************************************/
double f( double );
/****************************************************
*        主函数                                                                    *
****************************************************/
int main( void )
{
        double x_1, x_2, x_3;                        //定义横坐标
        double y_1, y_2, y_3;                        //定义相应的纵坐标,以减少调用函数的次数,以前没有想到这一点,程序中的重复计算越少越好
        int step;                                                //搜索步长
        double tmp;                                                //中间变量
       
        //初始化搜索
        step = 1;                                                //step的初值对搜索次数影响不大,因为调整时是按照幂次                                       
        x_1 = 0;                                                //x_1对搜索次数的影响很大
        y_1 = f( x_1 );
        x_2 = x_1 + step;
        y_2 = f( x_2 );
       
        //开始搜索
        if( y_2 > y_1 )                                        //调整搜索方向
        {
                step = -step;                                //C语言中有负号运算符
                tmp = x_1;                                        //对x_1和x_2进行交换
                x_1 = x_2;
                x_2 = tmp;
                tmp = y_1;                                        //对y_1和y_2进行交换
                y_1 = y_2;
                y_2 = tmp;
        }
        else                                                        //空语句可以增加程序的易读性
        {
                ;
        }

往事并不如烟
3楼2011-12-15 21:53:03
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wangyuewu08

专家顾问

优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!

【答案】应助回帖


jjdg(金币+1): 辛苦了 2011-12-16 01:14:13
刚刚没有全选
CODE:
/****************************************************************
*        名称 :        确定搜索区间的外推法                                      *
*        说明 :        假设函数f( x )具有单谷性,即在所考虑的区间内部,          *
*                          函数f( x )有唯一的极小点x0。为了确定极小点x所在           *
*                          的区间,应使函数f( x )在[ a, b ]区间内形成                *
*                          “高-低-高”趋势。                                        *
*        作者 :        ***                                                                                                *
*        日期 :        2011-05-22                                                                                         *
****************************************************************/
#include

/****************************************************
*        函数声明                                                            *
****************************************************/
double f( double );
/****************************************************
*        主函数                                                                    *
****************************************************/
int main( void )
{
        double x_1, x_2, x_3;                        //定义横坐标
        double y_1, y_2, y_3;                        //定义相应的纵坐标,以减少调用函数的次数,以前没有想到这一点,程序中的重复计算越少越好
        int step;                                                //搜索步长
        double tmp;                                                //中间变量
       
        //初始化搜索
        step = 1;                                                //step的初值对搜索次数影响不大,因为调整时是按照幂次                                       
        x_1 = 0;                                                //x_1对搜索次数的影响很大
        y_1 = f( x_1 );
        x_2 = x_1 + step;
        y_2 = f( x_2 );
       
        //开始搜索
        if( y_2 > y_1 )                                        //调整搜索方向
        {
                step = -step;                                //C语言中有负号运算符
                tmp = x_1;                                        //对x_1和x_2进行交换
                x_1 = x_2;
                x_2 = tmp;
                tmp = y_1;                                        //对y_1和y_2进行交换
                y_1 = y_2;
                y_2 = tmp;
        }
        else                                                        //空语句可以增加程序的易读性
        {
                ;
        }
       
        x_3 = x_2 + step;                                //为了减少代码的长度,应该修改成do...while的形式
        y_3 = f( x_3 );                                        //但修改之后,逻辑性不强
        while( y_3 < y_2 )
        {
                x_1 = x_2;
                x_2 = x_3;
                x_3 = x_2 + step;
                y_1 = y_2;
                y_2 = y_3;
                y_3 = f( x_3 );
                step = 2 * step;
        }
       
        if( x_1 > x_3 )                                        //将区间按照从小到大的顺序调整,只需调整两端点
        {                                                                //这样调整是为了符合“左小右大”的习惯
                tmp = x_1;
                x_1 = x_3;
                x_3 = tmp;
                tmp = y_1;
                y_1 = y_3;
                y_3 = tmp;
        }
       
        printf( "x_1 = %f, x_2 = %f, x_3 = %f\n", x_1, x_2, x_3 );
        printf( "y_1 = %f, y_2 = %f, y_3 = %f\n", y_1, y_2, y_3 );
       
        return( 0 );                                        //返回0,表示程序结束
}
/********************************************************
*        函数名称 :        目标函数                                                                *
*   输入变量 :        横坐标x                                                                        *
*        输出变量 :        纵坐标y                                                             *
*        说    明 :        目标函数要求具有单谷性                                        *
********************************************************/
double f( double x )
{
        double y;
       
        y = x * x - 2 *x + 1;
       
        return( y );
}

往事并不如烟
4楼2011-12-15 21:54:58
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 求调剂:085600材料与化工,考材科基,总分319 +17 678lucky 2026-03-31 21/1050 2026-04-01 01:40 by 1018329917
[考研] 359求调剂 +7 邓邓邓书书 2026-03-25 7/350 2026-03-31 23:15 by fs26jie
[考研] 一志愿西交大080500材料学硕349 +6 jqx1258 2026-03-31 7/350 2026-03-31 21:08 by yuq
[考研] 考研调剂 +9 小蜡新笔 2026-03-29 10/500 2026-03-31 19:52 by Dyhoer
[考研] 求化学调剂 +12 wulanna 2026-03-28 12/600 2026-03-31 16:38 by 690616278
[考研] 085601 329分调剂 +6 yzsa12 2026-03-31 6/300 2026-03-31 15:23 by yanflower7133
[考研] 生物考研337分求调剂 +4 cgxin 2026-03-30 6/300 2026-03-31 14:18 by 记事本2026
[考研] 272求调剂,接受跨专业调剂! +3 闲鱼卢 2026-03-31 3/150 2026-03-31 13:00 by 替代品000
[考研] 一志愿南昌大学324求调剂 +6 hanamiko 2026-03-30 6/300 2026-03-31 12:19 by 唐沐儿
[考研] 320分,材料与化工专业,求调剂 +10 一定上岸aaa 2026-03-27 14/700 2026-03-31 10:47 by foria
[考研] 总分322求生物学/生化与分子/生物信息学相关调剂 +6 星沉uu 2026-03-26 7/350 2026-03-31 10:19 by GdShizy
[考研] 0817化工学硕调剂 +7 努力上岸中! 2026-03-31 7/350 2026-03-31 09:58 by nalakaiqi
[考研] 291求调剂 +12 Y-cap 2026-03-29 15/750 2026-03-31 09:25 by Huaxue_Wang
[考研] 083000环境科学与工程调剂,总分281 +4 橙子(胜意) 2026-03-30 4/200 2026-03-31 00:44 by Linzejun
[考研] 本科211总分289,08工学真心求调剂 +3 utopiaE 2026-03-30 3/150 2026-03-30 23:42 by ms629
[考研] 085601材料工程找调剂 +17 oatmealR 2026-03-29 18/900 2026-03-30 19:21 by Wang200018
[考研] 342求调剂 +4 加油a李zs 2026-03-26 4/200 2026-03-30 16:39 by 晶体之美
[考研] 303求调剂 +7 DLkz1314. 2026-03-30 7/350 2026-03-30 16:05 by shuang5186
[考研] 275求调剂 +15 Micky11223 2026-03-25 20/1000 2026-03-29 20:44 by 唐沐儿
[考研] 266求调剂 +11 阳阳哇塞 2026-03-27 12/600 2026-03-27 17:56 by yu221
信息提示
请填处理意见