6-176 黄金分割点查找法

博客介绍了如何将二分查找法改写成黄金分割点查找法,详细阐述了函数接口定义,并提供了裁判测试程序样例及输入输出样例,帮助理解如何在限定范围内查找特定元素的出现位置和查询次数。
摘要由CSDN通过智能技术生成

本题改写二分查找法为黄金分割点查找(即每次查找在left与right之间的0.618处),要求实现一个函数,采用黄金分割点法查找元素出现的位置及查询次数。

函数接口定义:

int Goldsearch (int a[],int n,int x,int &count);

其中 n 是用户传入的参数,表示数组长度。 x 的值不超过int的范围,是需查询的元素。count表示查询的次数,初值为0,程序调用时通过形参返回其值, 函数须返回 x 中 a 中出现的位置,-1表示未查到。

裁判测试程序样例:

#include <stdio.h>

int Goldsearch(int a[],int n,int x,int &count);

int main()
{

  int a[10]={2,4,6,8,10,12,14,16,18,20},x,num=0,res;
    
  scanf("%d",&x);

  res=Goldsearch(a,10,x,num);

  if(res&
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值