单链表的插入

#include <stdio.h>
#define null 0
typedef struct node
{int data;
 struct node*next;
}slnode;
void*initiate(slnode**h)
{*h=(slnode*)malloc(sizeof(slnode));
 (*h)->next=null;
 }

slnode append(slnode*p,int x)
{slnode*s;
 s=(slnode*)malloc(sizeof(slnode));
 s->data=x;
 s->next=p->next;
 p->next=s;
 }

slnode*search(slnode*p,int x)
{slnode*s;
 s=p->next;
 while(s!=null){
 if(s->data==x)return(s);
 s=s->next;}
 return(null);
 }

int insert(slnode*p, int x,int y)
{slnode*m,*n;
 n=(slnode*)malloc(sizeof(slnode));
 n->data=y;
 m=search(p,x);
 if(m!=null){
 n->next=m->next;
 m->next=n;
 return(0);
 }
 else
 {printf("%c not found/n",x);
 return(-1);
 }
 }

void travel(slnode*p)
{slnode*s;
 s=p->next;
 while(s!=null){
 putchar(s->data);
 s=s->next;
 }
 putchar('/n');
 }

main(){
 int i,ch1,ch2,n;
 slnode*q,*p;
 initiate(&p);
 for(i=1;i<4;i++){
   printf("ch%d=",i);

   ch1=getchar();
   getchar();
   append(p,ch1);
   printf("point ch%d=%c/n",i,ch1);
   }

 travel(p);
 printf("ch1=");
 ch1=getchar();
 getchar();
 printf("ch2=");
 ch2=getchar();
 getchar();
 insert(p,ch1,ch2);
 travel(p);
 }//注意这个插入是插在你输入的内容的后面。建立单链表的时候是后输入的在前面,至于想怎么修改,这个是很容易的。稍微改一下append函数就行了。
 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值