有N个数的数列,要求从键盘上输入一个数,用顺序查找法查找该数是否存在数列中。如果该数存在数列中,则打印出该数是数列中第几个元素;若不在,则打印出“无此数”的信息

rongmayiren_cf 2012-06-03 10:17:23
大神帮我改改程序啊

#include <iostream>
using namespace std;
int main(){
int i,num;
int list[10]={1,3,5,7,9,13,15,17,19,21};
cin>>num;
for(i=0;i<10;i++)
{
if(list[i]==num){
cout<<i+1<<endl;
break;
}

else cout<<"not found!"<<endl;
}
return 0;
}
...全文
1665 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
pathuang68 2012-06-04
  • 打赏
  • 举报
回复
看楼主给出的数组已经从小到大排好了序,那么用二分查找法效率应该会更高一些,下面的代码供参考:

#include <iostream>
using namespace std;
int main()
{
int i,num;
int list[10]={1,3,5,7,9,13,15,17,19,21};
cin>>num;

int start = 0;
int end = sizeof(list) / sizeof(list[0]) - 1;

while(true)
{
int temp = (start + end) / 2;
if(end - start == 1)
{
if(list[start] == num)
{
cout << "Position is " << start << endl;
break;
}
else if(list[end] == num)
{
cout << "Position is " << end << endl;
break;
}
else
{
cout << "Not found." << endl;
break;
}
}

if(list[temp] == num)
{
cout << "Position is " << (start + end) / 2 << endl;
break;
}

if(list[temp] < num)
{
start = temp;
}
else
{
end = temp;
}
}

return 0;
}
W170532934 2012-06-03
  • 打赏
  • 举报
回复

#include <iostream>
using namespace std;
int main(){
int i,num;
int list[10]={1,3,5,7,9,13,15,17,19,21};
cin>>num;
for(i=0;i<10;i++)
{
if(list[i]==num){
break;
}
}
if(i>=10)
cout<<"not found!"<<endl;
else
cout<<"Pos is "<<i+1<<endl;
return 0;
}

else加错地方了啊

65,208

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧