C高级--链表结构体组合

C高级

听(懵)讲(逼)感言

高级果然就是不一样,如云里来似风里去,听得恍如隔世不知窗外今夕是何年。上周初次接触链表(大学老师说好的用不到,不需要掌握,考试也不会考),感觉这好简单啊,他家有洗衣机我家没有,他家有地址指向我家,我家地址指向隔壁老王家,隔壁老王.next指向NULL。怎么两天不见整个画风就变了是什么鬼!?满屏你指(ˇˍˇ) 向~我我指向你,不要把关系搞得这么复杂好吗。等等,好像是我自己把事情搞复杂了。

所有的->我都当的来读就是了,一下子程序顺溜了好多。再看仔细点,哎呀妈呀,所有的结构都一样一样的,链表不会我结构体会啊,以结构体的思想来对待链表,很简单的指向。最后简化成三部分:

head头结点+中间链接部分+尾部指向NULL。

先来段初阶头插法

#include <stdio.h>
#include <stdlib.h>
typedef struct Student
{
    char name[10];
    int num;
}Student;
typedef struct LINK
{
    Student data;
    struct LINK *next;
}LINK,*pLINK;
int main()
{
    //1.头结点的制备
    pLINK head=(pLINK)malloc(sizeof(LINK));//此处用到malloc函数在堆区分配空间给head
    head->next=NULL;//head初始指向NULL。
    //2.头插法基本入门(此处将内容插入头尾间,且可多次利用)
    pLINK p=(pLINK)malloc(sizeof(LINK));
    p->next=head->next;
    head->next=p;
    Student stu;
    printf("请输入学生信息[name num]:\n");
    scanf ("%s%d",stu.name,&stu.num);
    p->data=stu;
    //3.打印数据
    pLINK temp=head->next;
    for(temp=head->next;temp!=NULL;temp=temp->next)
    {
        printf("name=%s,num=%d\n",temp->data.name,temp->data.num);
    }
}

把以上的程序加以理解以后,我们的链表基础就有了。然后我们就想,能不能分模块封装。

答案是明显的

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void myScanf(char *str,int size);
typedef struct Student
{
    char name[10];
    int num;
}Student;
typedef struct LINK
{
    Student data;
    struct LINK *next;
}LINK,*pLINK;
pLINK createList(pLINK head)
{
    if(NULL==head)
    {
        head=(pLINK)malloc(sizeof(LINK));
        head->next=NULL;
        printf("链表创建成功\n");
    }
    return head;
}
void printdata(pLINK head)
{
    if(NULL==head)
    {
        printf("无信息打印\n");
        return;
    }
    pLINK temp=head->next;
    printf("head-->");
    for(temp=head->next;temp!=NULL;temp=temp->next)
    {
        printf("[name=%s,num=%d]-->",temp->data.name,temp->data.num);
    }
    printf("NULL\n");
}
Student getData();
void headInsertData(pLINK head)
{
    pLINK p=(pLINK)malloc(sizeof(LINK));
    p->next=head->next;
    head->next=p;
    p->data=getData();
    printf("数据插入成功\n");
}
Student getData()
{
    printf("请输入学生信息[name num]:\n");
    Student stu;
    myScanf(stu.name,20);
    scanf("%d",&stu.num);
    return stu;
}
void tailInsertData(pLINK head);
void randomInsertData(pLINK head)
{
    int i=0,num;
    pLINK temp;
    for(temp=head;temp!=NULL;temp=temp->next)
    {
        i++;
    }
    printf("此时链表长度为%d\n",i);
    printf("输入想插入的位置\n");
    scanf("%d",&num);
    getchar();
    if(num==1)
    {
        headInsertData(head);
        return;
    }
    if(num==i)
    {
        tailInsertData(head);
        return;
    }
    if(num>1&&num<i)
    {
        int a=0;
        for(temp=head;temp!=NULL;temp=temp->next)
        {
            a++;
            if(a==num)
            {
                break;
            }
        }
        printf("跳出位置num=%d\n",temp->data.num);
        pLINK p=(pLINK)malloc(sizeof(LINK));
        p->next=temp->next;
        temp->next=p;
        p->data=getData();
        printf("插入成功\n");
    }
    else
        printf("插你大爷,麻烦找对地儿\n");
    return;
/*  pLINK p=(pLINK)malloc(sizeof(LINK));
    p->data=getData();
    temp->next=p;
    p->next=temp->next->next;
    printf("在%d位插入数据成功\n",num);*/
}
void tailInsertData(pLINK head)
{
    //找尾指针:最后一个节点的的地址
    pLINK temp;
    for(temp=head;temp->next!=NULL;temp=temp->next);
    //跳出的条件:temp->next==null;
    pLINK p=(pLINK)malloc(sizeof(LINK));
    p->data=getData();
    temp->next=p;
    p->next=NULL;
    printf("尾插数据成功\n");
}
void headDeleteData(pLINK head)
{
    if (head==NULL||head->next==NULL)
    {
        printf("信息删除失败\n");
        return;
    }
    pLINK p=head->next;
    head->next=p->next;
    free(p);
    p=NULL;
    printf("删除信息成功\n");
}
void tailDeleteData(pLINK head)
{
    pLINK temp;
    for(temp=head;temp->next->next!=NULL;temp=temp->next);
    pLINK p=temp->next;
    temp->next=NULL;
    free(p);
    p=NULL;
    printf("信息删除成功\n");
}
void randomDeleteData(pLINK head)
{
    if (head==NULL||head->next==NULL)
    {
        printf("没信息可删\n");
        return;
    }
    int i=0,num;
    pLINK temp;
    for(temp=head->next;temp!=NULL;temp=temp->next)
    {
        i++;
    }
    printf("此时链表长度为%d\n",i);
    printf("输入想删除的位置\n");
    scanf("%d",&num);
    getchar();
    if(num==1)
    {
        headDeleteData(head);
        return;
    }
    if(num==i)
    {
        tailDeleteData(head);
        return;
    }
    if(num>1&&num<i)
    {
        int a=1;
        for(temp=head->next;temp!=NULL;temp=temp->next)
        {
            a++;
            if(a==num)
            {
                break;
            }
        }
        printf("跳出位置num=%d\n",temp->data.num);
        pLINK p=temp->next;
        temp->next=p->next;
        free(p);
        p=NULL;
        printf("删除成功\n");
    }
    else
        printf("删你大爷,拜托睁亮眼\n");
    return;
}
void insertData(pLINK head)
{
    if(head==NULL)
    {
        printf("插入数据失败\n");
        return;
    }
    int select;
    while(1)
    {
        printf("============\n");
        printf("1.头插数据:\n");
        printf("2.尾插数据:\n");
        printf("3.任意位置插:\n");
        printf("4.返回上一层\n");
        printf("============\n");
        scanf("%d",&select);
        getchar();
        switch(select)
        {
            case 1: headInsertData(head);break;
            case 2: tailInsertData(head);break;
            case 3: randomInsertData(head);break;
            case 4: return;
            default:break;
        }
    }
}
void deleteData(pLINK head)
{
    if (head==NULL||head->next==NULL)
    {
        printf("没信息可删\n");
        return;
    }
    int select;
    while(1)
    {
        printf("============\n");
        printf("1.头删数据:\n");
        printf("2.尾删插数据:\n");
        printf("3.任意位置删:\n");
        printf("4.返回上一层\n");
        printf("============\n");
        scanf("%d",&select);
        getchar();
        switch(select)
        {
            case 1: headDeleteData(head);break;
            case 2: tailDeleteData(head);break;
            case 3: randomDeleteData(head);break;
            case 4: return;
            default:break;
        }
    }
}
void myScanf(char *str,int size)
{
    int i;
    for (i=0;i<size-1;i++)
    {   
        str[i]=getchar();
        if(str[i]=='\n')
        {
            break;
        }
    }
    //如果中途遇到\n
    if(str[i]=='\n')
    {
        str[i]='\0';
    }
    else
    {
        str[i]='\0';
        while(getchar()!='\n');
    }
}
void searchData(pLINK head)
{
    if(head==NULL||head->next==NULL)
    {
        printf("无信息查询\n");
        return;
    }
    int num;
    printf("输入想查询的学号\n");
    scanf("%d",&num);
    pLINK temp;
    for(temp=head->next;temp!=NULL;temp=temp->next)
    {
        if(temp->data.num==num)
        {
            printf("name=%s num=%d\n",temp->data.name,temp->data.num);
            return;
        }
    }
    if(temp==NULL)
    {
        printf("查无此人\n");
    }
}
void changeData(pLINK head)
{
    if(head==NULL||head->next==NULL)
    {
        printf("无信息可修改\n");
        return;
    }
    char name[20];
    pLINK temp;
    printf("请输入姓名\n");
    myScanf(name,20);
    printf("====\n");
    for(temp=head->next;temp!=NULL;temp=temp->next)
    {
        if(strcmp(temp->data.name,name)==0)
        {
            printf("该学生原来的信息[name=%s num=%d]\n",temp->data.name,temp->data.num);
            printf("请输入要修改的信息[姓名 学号]\n");
            Student stu;
            myScanf(stu.name,20);
            scanf("%d",&stu.num);
            getchar();
            temp->data=stu;
            printf("信息修改成功\n");
            return;
        }
        if(temp==NULL)
        {
            printf("查无此人\n");
        }
    }
}
int main()
{
    int select;
    pLINK head=NULL;
    while(1)
    {
        printf("============\n");
        printf("1.创建链表:\n");
        printf("2.插入数据:\n");
        printf("3.删除数据\n");
        printf("4.打印数据:\n");
        printf("5.查找信息\n");
        printf("6.修改数据\n");
        printf("7.结束\n");
        printf("============\n");
        scanf("%d",&select);
        getchar();
        switch(select)
        {
            case 1: head=createList(head);break;
            case 2: insertData(head);break;
            case 3: deleteData(head);break;
            case 4: printdata(head);break;
            case 5: searchData(head);break;
            case 6: changeData(head);break;
            case 7:return 0;
            defaulf:break;
        }
    }
}

三百行的程序一脑懵逼,不过因为分了模块。所以简单易懂易改错。
晚上加了选择行数删除与插入。做了两小时,明明很简单,但是做了好久,就因为不熟练。。而且自己打英文的速度与中文成反比,求指导。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,015评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,262评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,727评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,986评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,363评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,610评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,871评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,582评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,297评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,551评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,053评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,385评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,035评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,079评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,841评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,648评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,550评论 2 270

推荐阅读更多精彩内容

  • 2016年国庆假期终于把此书过完,整理笔记和体会于此。 关于书名 书名源于俄罗斯的演员斯坦尼斯拉夫斯基创作的《演员...
    李剑飞的简书阅读 7,126评论 2 65
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,295评论 18 399
  • 第一章 Nginx简介 Nginx是什么 没有听过Nginx?那么一定听过它的“同行”Apache吧!Ngi...
    JokerW阅读 32,462评论 24 1,003
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,100评论 18 139
  • Java 抽象类在面向对象的概念中,所有的对象都是通过类来描绘的,但是反过来,并不是所有的类都是用来描绘对象的,如...
    没说再见阅读 271评论 0 0