| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 330 人关注过本帖
标题:(链表)请帮助修改错误!
只看楼主 加入收藏
rjyy
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2007-8-1
收藏
 问题点数:0 回复次数:1 
(链表)请帮助修改错误!

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define NULL 0
#define MAX 100
typedef struct l
{
char data;
struct l *link;
}list;

list *create()
{
list *h,*p;
int i,n;
char a[MAX];
printf("请输入结点个数:\n");
scanf("%d",&n);
h=(list *)malloc(sizeof(list));
h->link=NULL;
for(i=0;i<n;i++)
{
p=(list *)malloc(sizeof(list));
printf("请输入数组的值:\n");
scanf("%s",&a[i]);
p->link=h->link;
h->link=p;
p->data=a[i];
}
return h;
}

list *add(list *h)
{
list *p;
char t[MAX];
int i,m;
printf("请输入插入的结点的个数:\n");
scanf("%d",&m);
for(i=0;i<m;i++)
{
p=(list *)malloc(sizeof(list));
printf("请输入插入的结点的值:\n");
scanf("%s",&t[i]);
p->data=t[i];
p->link=h->link;
h->link=p;
}
return h;
}

void del(list *h,int n)
{
list *p,*q;
int i;
char b[8];
p=h->link;
q=h;
printf("请输入要查找的结点的名称:\n");
scanf("%s",&b);
if(h->link==NULL)
printf("the list is NULL!\n");
else
for(i=0;i<n;i++)
{
q=p;
p=p->link;
if(strcmp(p.data,b)==0)
{
q->link=p->link;
free(p);
}
}
}

void print(list *h)
{
list *p;
p=h->link;
for(;p;p=p->link)
printf("%s",p->data);
}

void main()
{
list *head;
int n;
head=(list *)malloc(sizeof(list));
head->link=NULL;
printf("请输入结点个数:\n");
scanf("%d",&n);
head=create();
print(head);
add(head);
print(head);
del(head,n);
print(head);
}

搜索更多相关主题的帖子: 链表 
2007-08-01 20:21
melodylsp
Rank: 1
等 级:新手上路
帖 子:35
专家分:0
注 册:2007-7-22
收藏
得分:0 
scanf("%s",&a[i]);
错了

2007-08-01 23:47
快速回复:(链表)请帮助修改错误!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.015180 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved