网页资讯视频图片知道文库贴吧地图采购
进入贴吧全吧搜索

 
 
 
日一二三四五六
       
       
       
       
       
       

签到排名:今日本吧第个签到,

本吧因你更精彩,明天继续来努力!

本吧签到人数:0

一键签到
成为超级会员,使用一键签到
一键签到
本月漏签0次!
0
成为超级会员,赠送8张补签卡
如何使用?
点击日历上漏签日期,即可进行补签。
连续签到:天  累计签到:天
0
超级会员单次开通12个月以上,赠送连续签到卡3张
使用连续签到卡
05月16日漏签0天
软件工程吧 关注:97,081贴子:212,308
  • 看贴

  • 图片

  • 吧主推荐

  • 视频

  • 游戏

  • 2回复贴,共1页
<<返回软件工程吧
>0< 加载中...

求教 各路大神路过进来看看

  • 只看楼主
  • 收藏

  • 回复
  • a156154710
  • 还是菜鸟
    3
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
#include <iostream>
#include <cstdlib>
#include <ctime>
using namespace std;
int partion(int a[],int p,int r){
srand((unsigned)time( NULL));
int e=rand()%(r-p+1)+p;
int tem;
tem=a[e];
a[e]=a[r];
a[r]=tem;
int x=a[r], i=p-1;
for (int j=p;j<r;j++){
if (a[j]<=x){
tem=a[i+1];
a[i+1]=a[j];
a[j]=tem;
i++;
}
}
tem=a[r];
a[r]=a[i+1];
a[i+1]=tem;
return i+1;
}
int Binsch(int A[],int low,int high,int key)
{
if(low<high)
{
int mid=(low+high)/2;
if(key==A[mid])
return mid;
else if(key<A[mid])
return Binsch(A,low,mid-1,key);
else
return Binsch(A,mid+1,high,key);
}
else return -1;
}
void QuickSort(int a[],int p,int r){
if (p<r){
int q=partion(a,p,r);
QuickSort(a,p,q-1);
QuickSort(a,q+1,r);
}
}
int main(int i,int array[],int yes,int Key){
cout<<"随机十个数:";
for(i=0;i<10;i++)
cin>>array[i];
QuickSort(array,0,9);
cout<<"排序后的数组:";
for(i=0;i<=9;i++)
cout<<array[i]<<" ";
printf("\n 查找数请按--------------1\n");
printf("\n 退出查找请按——————0\n\n");
printf("要查找元素吗?是(按1)否(按0)\n");
scanf("%d",&yes);
while(yes==1)
{
int z=1;
cout<<"输入要查找的数: ";
cin>>z;
int x=Binsch(array,0,9,z);
cout<<"查找的位置在: ";
cout<<x+1<<" ";
printf("\n要继续查找吗?是(按1)否(按0)\n");
scanf("%d",&yes);
}
}


  • a156154710
  • 还是菜鸟
    3
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼


2025-05-16 08:48:15
广告
  • a156154710
  • 还是菜鸟
    3
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
为什么后面结果不对了呢 哪里错了吗


登录百度账号

扫二维码下载贴吧客户端

下载贴吧APP
看高清直播、视频!
  • 贴吧页面意见反馈
  • 违规贴吧举报反馈通道
  • 贴吧违规信息处理公示
  • 2回复贴,共1页
<<返回软件工程吧
分享到:
©2025 Baidu贴吧协议|隐私政策|吧主制度|意见反馈|网络谣言警示