我想知道如何完成这个程序。在列表上执行线性搜索" ll" (用户输入的项目长度为31),返回用户输入的号码及其位置(如果找到的话)。
问题:我不确定如何在这个特定场景中调用函数,我不需要使用指针或传递值,所以缺少这些实际上会让我更加困惑,因为那些是相当常见的情况。
#include <iostream> //enables usage of cin and cout
#include <cstring>
using namespace std;
int search (int i, int it, int ll, int z);
int printit (int i, int it, int ll, int z);
int main ()
{
int i,it,z;
int ll[] = {2,3,4,5,6,2,3,44,5,3,5,3,4,7,8,99,6,5,7,56,5,66,44,34,23,11,32,54,664,432,111}; //array hardwired with numbers
//call to search
return 0;
}
int search (int i, int it, int ll, int z)
{
cout << "Enter the item you want to find: "; //user query
cin >> it; //"scan"
for(i=0;i<31;i++) //search
{
if(it==ll[i])
{
//call to printit
}
}
return 0;
}
int printit (int i, int it, int ll, int z)
{
cout << "Item is found at location " << i+1 << endl;
return 0;
}
答案 0 :(得分:1)
每个参数search
都有问题:
i
传递的值在被使用之前会被覆盖,因此应该是一个局部变量it
ll
应该是int
的数组 z
并未全部使用 printit
的情况更糟:4个参数中有3个被忽略。
答案 1 :(得分:0)
如果您已经打印出结果,则搜索和打印不需要返回int。一些声明的变量也是无用的。以下代码可以使用:
#include <iostream> //enables usage of cin and cout
#include <cstring>
using namespace std;
void search (int ll[]);
void printit (int n);
int main ()
{
// int i,it,z;
int ll[] = {2,3,4,5,6,2,3,44,5,3,5,3,4,7,8,99,6,5,7,56,5,66,44,34,23,11,32,54,664,432,111}; //array hardwired with numbers
//call to search
search(ll);
return 0;
}
void search (int ll[])
{
cout << "Enter the item you want to find: "; //user query
cin >> it; //"scan"
for(i=0;i<31;i++) //search
{
if(it==ll[i])
{
//call to printit
printit(i);
}
}
// return 0;
}
void printit (int n)
{
cout << "Item is found at location " << n+1 << endl;
// return 0;
}