单链表字符串输入,还要实现增删改查!急急急!求解!

bayigang1688 2014-07-04 11:10:41
怎样才能让单链表实现字符串输入,还要实现增删改查!急急急!求解!求源码
...全文
223 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
bayigang1688 2014-07-17
  • 打赏
  • 举报
回复
一楼正解,结贴!
简书成研 2014-07-04
  • 打赏
  • 举报
回复
哥们 直接遍历 它的数据域就可以了撒,搞那么麻烦还不如使用 STL 中的容器更爽,STL就是对数据结构的封装
bayigang1688 2014-07-04
  • 打赏
  • 举报
回复
嗯嗯,代码写的很详细,这些我基本都实现了,现在的问题是,所有的数据要用字符串输入并打印出来,每一次的增删改查实现的同时,打印出相对应的结果(链表存放的数据是字符串),求指点啊!!!
简书成研 2014-07-04
  • 打赏
  • 举报
回复
#include <stdio.h> 
#include <stdlib.h> 
  
typedef int ElemType; 
////////////////////////////////////////////  
  
//定义结点类型  
typedef struct Node 
{ 
    ElemType data;              //单链表中的数据域  
    struct Node *next;          //单链表的指针域  
}Node,*LinkedList; 
  
////////////////////////////////////////////  
  
//单链表的初始化 
  
LinkedList LinkedListInit() 
{ 
    Node *L; 
    L = (Node *)malloc(sizeof(Node));   //申请结点空间  
    if(L == NULL)                       //判断是否有足够的内存空间  
        printf("申请内存空间失败\n"); 
    L->next = NULL;                  //将next设置为NULL,初始长度为0的单链表  
} 
  
////////////////////////////////////////////  
  
//单链表的建立1,头插法建立单链表 
  
LinkedList LinkedListCreatH() 
{ 
    Node *L; 
    L = (Node *)malloc(sizeof(Node));   //申请头结点空间 
    L->next = NULL;                      //初始化一个空链表 
      
    ElemType x;                         //x为链表数据域中的数据 
    while(scanf("%d",&x) != EOF) 
    { 
        Node *p; 
        p = (Node *)malloc(sizeof(Node));   //申请新的结点  
        p->data = x;                     //结点数据域赋值  
        p->next = L->next;                    //将结点插入到表头L-->|2|-->|1|-->NULL  
        L->next = p;  
    } 
    return L;  
}  
  
////////////////////////////////////////////  
  
//单链表的建立2,尾插法建立单链表 
  
LinkedList LinkedListCreatT() 
{ 
    Node *L; 
    L = (Node *)malloc(sizeof(Node));   //申请头结点空间 
    L->next = NULL;                  //初始化一个空链表 
    Node *r; 
    r = L;                          //r始终指向终端结点,开始时指向头结点  
    ElemType x;                         //x为链表数据域中的数据 
    while(scanf("%d",&x) != EOF) 
    { 
        Node *p; 
        p = (Node *)malloc(sizeof(Node));   //申请新的结点  
        p->data = x;                     //结点数据域赋值  
        r->next = p;                 //将结点插入到表头L-->|1|-->|2|-->NULL  
        r = p;  
    } 
    r->next = NULL;  
      
    return L;    
} 
  
////////////////////////////////////////////  
  
//单链表的插入,在链表的第i个位置插入x的元素 
  
LinkedList LinkedListInsert(LinkedList L,int i,ElemType x) 
{ 
    Node *pre;                      //pre为前驱结点  
    pre = L; 
    int tempi = 0; 
    for (tempi = 1; tempi < i; tempi++) 
        pre = pre->next;                 //查找第i个位置的前驱结点  
    Node *p;                                //插入的结点为p 
    p = (Node *)malloc(sizeof(Node)); 
    p->data = x;  
    p->next = pre->next; 
    pre->next = p; 
      
    return L;                            
}  
  
////////////////////////////////////////////  
  
//单链表的删除,在链表中删除值为x的元素 
  
LinkedList LinkedListDelete(LinkedList L,ElemType x) 
{ 
    Node *p,*pre;                   //pre为前驱结点,p为查找的结点。  
    p = L->next; 
    while(p->data != x)              //查找值为x的元素  
    {    
        pre = p;  
        p = p->next; 
    } 
    pre->next = p->next;          //删除操作,将其前驱next指向其后继。  
    free(p); 
    return L; 
}  
  
///////////////////////////////////////////// 
  
int main() 
{ 
    LinkedList list,start; 
/*  printf("请输入单链表的数据:");  
    list = LinkedListCreatH(); 
    for(start = list->next; start != NULL; start = start->next) 
        printf("%d ",start->data); 
    printf("\n"); 
*/  printf("请输入单链表的数据:");  
    list = LinkedListCreatT(); 
    for(start = list->next; start != NULL; start = start->next) 
        printf("%d ",start->data); 
    printf("\n"); 
  
    int i; 
    ElemType x; 
    printf("请输入插入数据的位置:"); 
    scanf("%d",&i); 
    printf("请输入插入数据的值:"); 
    scanf("%d",&x); 
    LinkedListInsert(list,i,x); 
    for(start = list->next; start != NULL; start = start->next) 
        printf("%d ",start->data); 
    printf("\n"); 
    printf("请输入要删除的元素的值:"); 
    scanf("%d",&x); 
    LinkedListDelete(list,x);  
    for(start = list->next; start != NULL; start = start->next) 
        printf("%d ",start->data); 
    printf("\n"); 
      
    return 0; 
} 
707wk 2014-07-04
  • 打赏
  • 举报
回复
http://pan.baidu.com/s/17yIcQ可以在这堆代码中找
课程目标:学习Java语言中字符串相关的知识、字符编码常识和正则表达式的使用,并完成案例前导课程:《Java工程师必学系列课程》前4部课程内容:本课程是《Java工程师必学系列课程》的第5部分,主要讲解Java语言中字符串相关知识、字符编码常识和正则表达式的使用。本课程涉及的主要内容可以分为四部分:一、String、StringBuffer和StringBuilder类基本常识、基本原理和使用技巧二、字符编码常识三、Java语言正则表达式的详细语法和使用技巧四、实战案例课程说明:在开发Java程序的过程中,最常用的类莫过于字符串相关的类。可以毫不夸张的说,任何一个Java程序,都离不开对字符串保存和处理。很多学员对字符串的理解只是处于比较粗浅的阶段。殊不知,如果对字符串处理的不好,会影响到软件的运行效率。本课程专门讲解字符串相关的知识,将从字符串的存储方式、底层的运行方式等各方面深入讲解其中的原理和技巧。此外,对字符串进行更高级的处理,又要用到正则表达式的相关知识。正则表达式广泛应用于各种与字符串处理相关的场合。它是一套独立的语言系统,经过几十年的完善和发展,现在已经非常的强大,并且形成了国际标准。各种高级编程语言,都实现了自己的表达式引擎。本课程详细的讲解了Java语言中正则表达式的语法和使用技巧。掌握了正则表达式,对编程水平的提高有非常大的帮助!同时,本课程在最后一部分,安排了非常精彩的、完整的实战案例,通过实战的形式切实帮助学员提高解决具体问题的能力!预期效果:认真学习完本课程,学员可以掌握字符串处理及正则表达式相关的系统知识,并能提高实际的编码水平。环境配置要求:学习本课程需安装JDK1.8或更高版本的JDK,以便程序能正确运行,建议使用IntelliJ IDEA 2019.1.2或更高版本的开发工具。    因有合作协议约束,《穆哥学堂》只提供PDF版本的课件!

69,370

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧