/*
*copyright (c)2014,烟台大学计算机学院
*All rights reserved
*文件名称:2.cpp
*作者:孙春红
*完成日期:2014年3月1日
*版本号:v1.0
*
*问题描述:编写函数delete_node(int x),删除值为x的结点。
*输入描述:略。
*程序输出:略。
*/
#include <iostream>
using namespace std;
struct Node
{
int data; //结点的数据
struct Node *next; //指向下一结点
};
Node *head=NULL; //将链表头定义为全局变量,以便于后面操作
void make_list2();
void out_list(); //输出链表
void delete_node(int x); //删除结点
int main( )
{
int x;
make_list2();
out_list();
cout<<"请输入要删除的数字:"<<endl;
cin>>x;
delete_node(x);
out_list();
return 0;
}
void make_list2()
{
int n;
Node *p,*q;
cout<<"输入若干正数(以0或一个负数结束)建立链表:"<<endl;
cin>>n;
while (n>0)
{
p=new Node;
p->data=n;
p->next=NULL;
if(head==NULL)
head=p;
else
q->next=p;
q=p;
cin>>n;
}
return;
}
void out_list()
{
Node *p=head;
cout<<"链表中的数据为:"<<endl;
while(p!=NULL)
{
cout<<p->data<<" ";
p=p->next;
}
cout<<endl;
return;
}
void delete_node(int x)
{
Node *p,*q;
while (head!=NULL&&head->data==x)
{
p=head;
head=head->next;
delete p;
}//如果头结点的值为x,删除头结点
if (head!=NULL)
{
p=head;
q=p->next;
while (q!=NULL)
{
if (q->data==x)
{
p->next=q->next;
delete q;//删除值为x的q
}
else
{
p=q;
}
q=p->next;
}
}
return ;
}
运行结果:
知识点总结:
利用动态链表删除特定的数字,最重要的是理解程序是怎样运行的,链表是怎样运动的。
学习心得:
是在理解老师上课所讲的”利用指针*p、*q建立并输入一个简单的动态链表“才明白程序的。