微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用二进制搜索打印在结构向量中找到的大量值

如何解决使用二进制搜索打印在结构向量中找到的大量值

我得到了以下结构:

struct data
{
    string code;
    string description;
    float price;
};

用户将数据插入data a[]中之后,该程序应该查找并打印具有用户要求价格的产品(使用二进制搜索)。

这是我写的(n是用户插入的产品数):

void binary(int n,data a[])
{
    int last = 0,first = n-1,med,p;
    bool found = false;
    cout<<"\nInsert the price of the products you'd like to see: ";
    cin>>p;
    while(last <= first && !found)
    {
        med = (last + first)/2;
        if( a[med].price == p ) 
        { 
           print(med,a); 
           found = true;
        }
        else if( a[med].price > p ) 
           first = med - 1;
        else 
           last = med + 1;
    }
    if(found)
    {
        int pos = med;
        while(a[++pos].price == p)
        {
                print(pos,a);
        }
        while(a[--med].price == p)
        {
            print(pos,a);
        }
    }
    else 
        cout<<"\nThere are no products that have the price you've inserted";
}

打印功能如下:

void print(int x,data a[])
{

    cout<<"\nCode: " << a[x].code;
    cout<<"\nDescription: " << a[x].description;
    cout<<"\nPrice: " << a[x].price;

}

问题在于,当没有产品具有插入价格时,cout不会打印任何内容。 (因此它确实知道何时有符合标准的产品,但不会打印它们)。提前非常感谢您!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。