单链表尾插法1、2

#include <iostream>
using namespace std;

typedef char DataType;
typedef struct node{
        DataType data;
        struct node * next;
}ListNode;
typedef ListNode * LinkList;


LinkList CreateListR(){                          //方法1
         char ch;
         LinkList head;
         ListNode *s,*r;
         head=NULL;
         r=NULL;
         while((ch=getchar())!='x'){
            s=(ListNode *)malloc(sizeof(ListNode));
            s->data=ch;
            if(head==NULL){
                head=s;
            }
            else{
                 r->next=s;
            }
            r=s;
         }
         if(r!=NULL){
            r->next=NULL;
         }
         return head;
}

LinkList CreateListR1(){                          ///方法2
         char ch;
         LinkList head=(LinkList)malloc(sizeof(ListNode));
         ListNode *s,*r;
         r=head;
         while((ch=getchar())!='x'){
              s=(ListNode *)malloc(sizeof(ListNode));
              s->data=ch;
              r->next=s;
              r=s;
         }
         r->next=NULL;
         return head;
}    

 

 

//按第i个位置查找
ListNode * GetNode(ListNode head,int i){
         int j;
         ListNode *p;
         p=head;
         j=0;
         while(p->next && j<i){
           p=p->next;
           j++;
         }
         if(i==j){
           return p;
         }
         else{
           return NULL;
         }
}


//按值查找
ListNode *LocateNode(ListNode head,DataType key){
         ListNode *p=head->next;
         while(p&&p->data!=key){
           p=p->next;
         }
         return p;
}
        

void InsertList(LinkList head,DataType x,int i){
     ListNode *p;
     p=GetNode(head,i-1);
     if(p==NULL){
       cout<<"ERROR"<<endl;
     }
     s=(ListNode *)malloc(sizeof(ListNode));
     s->data=x;
     s->next=p->next;
     p->next=s;
}

void DeleteList(LinkList head,int i){
     ListNode *p,*r;
     p=GetNode(head,i-1);
     if(p==NULL || p->next==NULL){
       cout<<"ERROR"<<endl;
     }
     r=p->next;
     p->next=r->next;
     free(r);
}

 

 

 

int main(){
    CreateListR1();
    system("pause");
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值