链表数据查找是建立在完整代码上一种功能,其实就是一段子函代码。
因此以下代码是建立在之前的动态链表那篇博客的代码之上。
自观:
int find(pNode head,int number);
//以下代码段是增加段,契合本次查找功能。
printf("输入要查找的数\n");
scanf("%d",&number);
position=find(head,number);
//
//find函数定义
int find(pNode head,int number)
{
int cnt = 1;
pNode p=head->next;
while(p->data!=number&&p->next!=NULL)
{
cnt++;
p=p->next;
}
if(p->data!=number)
{
printf("查找的元素%d不在链表中。 \n",number);
return -1;
}
printf("查找的元素%d在链表中。\n",number);
return cnt;
}
while(p->data!=number&&p->next!=NULL)
{
cnt++;
p=p->next;
}
以上的循环体功能很明确,对整个链表进行一一查找,并作记录数字累加到一定——cnt++;