怎么搞啊,,需要用什么知识点???
最好能把代码写出来..
谢谢大家!!!!
不会这么简单吧
我着里有个程序的样本 你自己按照要求可以加上名字拉,成绩拉什么的
/*注意如果你的程序不支持中文就运行不了这个程序,*/
#include"stdio.h"
#include<alloc.h>
struct fun{
int data;
struct fun *next;
}*h,*r,*s,*v;
void chazhao();
void charu();
void shanchu();
void jiaohuan(int);
void print();
main()
{
int num,x;
printf("程序样本,只能输入数字(输入-1结束输入);\n");
h=(struct fun*)malloc(sizeof(struct fun));
r=h;
scanf("%d",&x);
while(x!=-1)
{
s=(struct fun*)malloc(sizeof(struct fun));
s->data=x;
r->next=s;
r=s;
scanf("%d",&x);
}
r->next=NULL;
print();
printf("1.查找\n2.插入\n3.删除\n4.显示\n");
scanf("%d",&num);
printf("\n运行结果\n");
switch(num)
{
case 1: chazhao();break;
case 2: charu(); break;
case 3:shanchu();break;
case 4:print();break;
}
}
void chazhao()
{
struct fun *p;
int i=0,k=0;
p=h;
printf("要查找的数:");
scanf("%d",&i);
for(;p!=NULL&&p->data!=i;k++)
p=p->next;
if(p!=NULL)
printf("值为%d的元素已经找到,在链表位置%d\n",i,k);
else
printf("没有找到\n");
print();
}
void charu()
{
struct fun *p;
int num,sum,i;
p=h;
printf("插入的位置:数");
scanf("%d:%d",&num,&sum);
for(i=0;i<num-1&&p!=NULL;i++)
p=p->next;
if(p==NULL)
printf("错误\n");
else{
s=(struct fun*)malloc(sizeof(struct fun));
s->data=sum;
s->next=p->next;
p->next=s;
}
print();
}
void shanchu()
{
struct fun *p,*u;
int i,sum;
p=h;
printf("要删除的位置");
scanf("%d",&sum);
for(i=0;i<sum-1&&p!=NULL;i++)
p=p->next;
if(p==NULL)
printf("错误\n");
else
{
u=p->next;
p->next=u->next;
free(u);
}
print();
}
void print()
{
struct fun *p;
p=h;
for(;p->next!=NULL;)
{
p=p->next;
printf("%d\n",p->data);
}
}
[此贴子已经被作者于2007-2-8 21:54:15编辑过]