天来总结C语言的学习盲点——结构体,为了不显单一,也为了补足作者链表的编程缺陷,特更此博文,总结近段时间的学习成果。话不多说,先上一段代码

struct none{int item; link next;};
typedef struct none *link; int main(int argc ,char *argv[])
{
int i , N = atoi(argv[1]) , M = atoi(argv[2]);
link t = malloc(sizeof(*t)) , x=t;
t->item = 1; t->next = t; for(i=2 ; i <= N ; i++)
{
x = x->next = malloc(sizeof(*x));
x->item = i; x->next = t;
} while(x != x->next)
{
for(i=1 ; i < M ; i++)
x = x->next;
x->next = x->next->next;
}
printf("%d\n",x->item);
return 0; }

上面这段代码是解决约瑟夫问题的一种算法

码开头两行定义一个链表的数据节点并为节点结构取一别名link,注意:使用typedef取别名不能定义新的数据结构,只能对现有结构取别名。主函数里获取执行程序时对主函数输入的参数,函数第一个参数argc保存输入参数个数,第二个参数argv保存输入参数(参数类型为字符串)。for循环执行添加N个链表节点,并让其首尾相连。此处作者想重点讲讲关于结构体的用法,指针结构体变量调用结构体成员使用-link->item或(link).item,其余使用a.item。并且->与.的优先级与()、[]比其它运算符优先级高,故a.data表示为*(a.data)、++a.data表示++(a.data),这些概念都是作者在初学结构体没有注意到的点,到实战中给作者带来不少麻烦,先一并归纳分享。while循环对选中的节点删除,直至剩余一个节点,最后输出剩下的节点数据。

要以为这样就结束了,程序还存在一些隐藏的bug,比如删除链表的节点去哪了,既然对节点分配了内存,删除的时候是否需要释放其内存呢,当然,如果程序比较小,系统资源充足,你可以这么干,但是对大型且安全要求较高的程序来说,由此造成的内存泄漏问题存在未知的风险,为了规避可能存在的风险,malloc应该与free配套使用,所以代码应改进为:

int main(int argc , char *argv[])
{ int i , N = atoi(argv[1]) , M = atoi(argv[2]);
link t = malloc(sizeof(*t)) , x=t , a;
t->item = 1; t->next = t; for(i=2 ; i <= N ; i++)
{
x = x->next = malloc(sizeof(*x));
x->item = i; x->next = t;
} while(x != x->next)
{
for(i=1 ; i < M ; i++)
x = x->next;
a = x->next ;
x->next= a->next;
free(a);
}
printf("%d\n",x->item);
return 0;
}

bug无尽,如有不足之处,欢迎各位道长分享评论

C结构体与链表的更多相关文章

  1. C语言语法笔记 – 高级用法 指针数组 指针的指针 二维数组指针 结构体指针 链表 | IT宅.com

    原文:C语言语法笔记 – 高级用法 指针数组 指针的指针 二维数组指针 结构体指针 链表 | IT宅.com C语言语法笔记 – 高级用法 指针数组 指针的指针 二维数组指针 结构体指针 链表 | I ...

  2. 六、golang中的结构体和方法、接口

    结构体: 1.用来自定义复杂数据结构 2.struct里面可以包含多个字段(属性) 3.struct类型可以定义方法,注意和函数的区分 4.strucr类型是值类型 5.struct类型可以嵌套 6. ...

  3. Linux设备驱动--块设备(二)之相关结构体

    上回最后面介绍了相关数据结构,下面再详细介绍 块设备对象结构 block_device 内核用结构block_device实例代表一个块设备对象,如:整个硬盘或特定分区.如果该结构代表一个分区,则其成 ...

  4. Linux设备驱动--块设备(二)之相关结构体(转)

    上回最后面介绍了相关数据结构,下面再详细介绍 块设备对象结构 block_device 内核用结构block_device实例代表一个块设备对象,如:整个硬盘或特定分区.如果该结构代表一个分区,则其成 ...

  5. linux块设备驱动---相关结构体(转)

    上回最后面介绍了相关数据结构,下面再详细介绍 块设备对象结构 block_device 内核用结构block_device实例代表一个块设备对象,如:整个硬盘或特定分区.如果该结构代表一个分区,则其成 ...

  6. 【原创】只学到二维数组和结构体,不用链表也能写一个C贪食蛇?(四)

    全系列Index: [原创]只学到二维数组和结构体,不用链表也能写一个C贪食蛇?(一) [原创]只学到二维数组和结构体,不用链表也能写一个C贪食蛇?(二) [原创]只学到二维数组和结构体,不用链表也能 ...

  7. C结构体变量2种运算(比如链表的结点)(区别与java)

    a结构体变量,只能做两种运算, 整体引用(赋值,参数传递) 或访问成员(点运算—地址方式简化,地址方式)(见最后的图片) case万: 结论:java里面的class Node : Node p; p ...

  8. c语言结构体链表

    原文链接:http://zhina123.blog.163.com/blog/static/417895782012106036289/ 引用自身的结构体,一个结构体中有一个或多个成员的基类型就是本结 ...

  9. go语言之行--结构体(struct)详解、链表

    一.struct简介 go语言中没有像类的概念,但是可以通过结构体struct实现oop(面向对象编程).struct的成员(也叫属性或字段)可以是任何类型,如普通类型.复合类型.函数.map.int ...

随机推荐

  1. Synchronized的jvm实现

    参考文档: https://www.cnblogs.com/dennyzhangdd/p/6734638.html

  2. 一个类似ThinkPHP的Node.js框架——QuickNode

    QuickNode Node.js从QuickNode开始,让restful接口开发更简单! PHP的MVC 作为一名曾经的PHP开发者,我也有过三年多的thinkphp使用经验,那是我学习PHP接触 ...

  3. python 前端素材提供

    小图标素材:http://fontawesome.dashgame.com/

  4. MyBatis学习总结之一对一映射

    知识点:JavaType和ofType都是用来指定对象类型的,但是JavaType是用来指定pojo中属性的类型,而ofType指定的是映射到list集合属性中pojo的类型. 本次mybatis的练 ...

  5. 吴裕雄--天生自然KITTEN编程:画三角形

  6. Myeclipse 错误An internal error has occurred 解决办法

    1. 给MyEclipse的快捷方式加个参数再重新启动一次.      步骤如下:右键选中快捷方式属性选项,在快捷方式页,目标一项最后加上-clean选项,如"C:\MyEclipse6\e ...

  7. 蚂蚁金服招聘-无线测试开发(20k-36k/月)

    蚂蚁金服-支付宝国际事业部-高级测试开发工程师/测试专家 工作年限:三年以上学历要求:本科期望层级:P6/P7工作地点:上海,杭州,深圳等为什么选择加入我们? 我们的岗位有何不同?1.国际化远景:随着 ...

  8. WEB端缓存机制

    WEB端缓存机制 什么是WEB缓存 Web缓存是指一个Web资源(如html页面,图片,js,数据等)存在于Web服务器和客户端(浏览器)之间的副本.缓存会根据进来的请求保存输出内容的副本:当下一个请 ...

  9. Spring Boot2.x 动态数据源配置

    原文链接: Spring Boot2.x 动态数据源配置 基于 Spring Boot 2.x.Spring Data JPA.druid.mysql 的动态数据源配置Demo,适合用于数据库的读写分 ...

  10. java反序列化-ysoserial-调试分析总结篇(4)

    1.前言 这篇文章继续分析commoncollections4利用链,这篇文章是对cc2的改造,和cc3一样,cc3是对cc1的改造,cc4则是对cc2的改造,里面chained的invoke变成了i ...