链表的创建,清空,插入,删除

typedef int (* __compfunc)(const void *, const void *);

//Traverse list. Fast macro to traverse the list.
#define linklist_next(al) \
      ((al) && ((al)=(al)->next) ? (al)->data : NULL) typedef struct linklist
{
  void *  data;
  struct linklist *  next;
} linklist_t; //Allocate a new list data structure
linklist_t * linklist_create()
{
linklist_t *ll;
ll = (linklist_t *) calloc(, sizeof(linklist_t));
return ll;
} //Destroy the list ll.
void linklist_destroy(linklist_t *ll)
{
if (ll) {
linklist_t *current = NULL;
while ((current=ll)) {ll = ll->next; free(current);}
}
} //Insert an element at the tail of a list.
int linklist_add(linklist_t *ll, void *data)
{
if (ll) {
linklist_t *node = NULL;
if ((node=(linklist_t *)calloc(, sizeof(linklist_t))) == )
return -;
while (ll->next) ll = ll->next;
node->data = data;
node->next = ll->next;
ll->next = node;
return ;
}
return -;
} //Remove element from the list.
int linklist_remove(linklist_t *ll, void *data)
{
if (ll) {
linklist_t *prev = NULL;
while (ll->next) {
prev = ll;
ll = ll->next;
if (ll->data == data) {
prev->next = ll->next;
free(ll);
return ;/* Success */
}
}//while
}
return ; /* object not found or NULL list */
} // Do an insertion sort algorithm on the list. An empty list is already
// sorted and so is a single element list.
int linklist_insert(linklist_t *ll, void *data, __compfunc cbcomp)
{
if (ll) {
linklist_t *node=NULL, *prev=NULL;
if (!cbcomp)
return linklist_add(ll, data);
if ((node=(linklist_t *)calloc(, sizeof(linklist_t))) == )
return -;
node->data = data;
if (!ll->next) {
ll->next = node;
return ;
}
for (prev=ll,ll=ll->next; ll; prev=ll,ll=ll->next) {
if (cbcomp(data, ll->data) <= ) {
prev->next = node;
node->next = ll;
return ;
}
}
prev->next = node;
}
return ;
} 4.链表的逆序
  1. LinkNode* ReverseLink(LinkNode* head)
  2. {
  3. LinkNode *prev=NULL, *next=NULL;
  4. while(head)
  5. {
  6. next = head->next;
  7. head->next = prev;
  8. prev = head;
  9. head = next;
  10. }
  11. return prev;
  12. }
 

C语言面试题分类->链表的更多相关文章

  1. C语言面试题分类->指针

    有关指针的经典面试题 C语言为何如此长寿并实用?C++为什么有那么多精彩?指针可以说是C/C++中的灵魂所在,虽然早期中pascal也有指针,但是和C/C++比起来不是一个级别的.今天为大家深入浅出的 ...

  2. C语言面试题22. 链表中倒数第k个节点

    要求:输入一个链表,输出该链表中倒数第k个节点.为了符合大多数人的习惯,本题从1开始计数,即链表的尾节点是倒数第1个节点.例如,一个链表有6个节点,从头节点开始,它们的值依次是1.2.3.4.5.6. ...

  3. C语言面试题分类->回调

    本文主要讲解如果实现回调,特别是在封装接口的时候,回调显得特别重要,我们首先假设有两个程序员在写代码,A程序员写底层驱动接口,B程序员写上层应用程序,然而此时底层驱动接口A有一个数据d需要传输给B,此 ...

  4. C语言面试题分类->字符串处理

    1.strlen:计算字符串长度(不包含'\0') 实现想法:遍历字符串,直到'\0'结束 #include<stdio.h> #include<stdlib.h> #incl ...

  5. C语言面试题分类->排序算法

    1.选择排序. 每次将最小的数,与剩余数做比较.找到更小的,做交换. 时间复杂度:O(n²) 空间复杂度:O(1) 优缺点:耗时但内存空间使用小. void selectSort(int *p,int ...

  6. C语言面试题分类->位运算

    1.不用临时变量交换两个整数. a = a ^ b; b = a ^ b; a = a ^ b; 2.实现一个函数,输入一个整数,输出该数二进制表示中1的个数.例如9的二进制是1001,则输出2. i ...

  7. C语言面试题分类->宏定义

    1.写一个“标准”宏,这个宏输入两个参数并返回较小的一个 答:#define MIN(x, y) ((x)<(y)?(x):(y))//注意x,y要加括号,因为x,y如果有复合运算会出现问题. ...

  8. 嵌入式开发—C语言面试题

    嵌入式开发—C语言面试题 源地址:http://blog.csdn.net/xdx2ct1314/article/details/7358929   1. 用预处理指令#define 声明一个常数,用 ...

  9. 转 C语言面试题大汇总

    转 C语言面试题大汇总,个人觉得还是比较全地!!! \主 题:   C语言面试题大汇总,个人觉得还是比较全地!!!  作 者:   free131 (白日?做梦!)   信 誉 值:   100    ...

随机推荐

  1. php输出语句 echo print printf print_r var_dump sprintf

    php的几种输出方式: echo 常用的输出语句,例如:echo 'helloworld!'; print() 输出语句,有返回值.例如:print('helloworld!'); 输出成功返回1,失 ...

  2. c++入门篇七

    拷贝构造函数的调用时机: class Person { public: //构造函数 Person() { //无参构造函数 } Person(int a) { //有参构造函数 cout <& ...

  3. Django—第三方引用

    索引 一.富文本编辑器 1.1 在Admin中使用 1.2 自定义使用 1.3 显示 二.全文检索 2.1 创建引擎及索引 2.2 使用 三.发送邮件 一.富文本编辑器 借助富文本编辑器,网站的编辑人 ...

  4. 经验分享:PDF怎么提取页面

    PDF文件的页面有很多但有需要的并不是全部,有时候需要其中一页或几页的时候,这个时候我们就需要把单独的页面提取出来,这个时候应该怎么做呢,上次有小伙伴来询问小编,今天小编就为大家分享一下小编自己的编辑 ...

  5. Redis在Linux中安装使用

    一.安装$ wget http://download.redis.io/releases/redis-x.x.x.tar.gz $ tar xzf redis-x.x.x.tar.gz $ cd re ...

  6. CSRF & CORS 的区别

    转发 CSRF & CORS 的区别 下面转的两篇文章分别说明了以下两个概念和一些解决方法: 1. CSRF - Cross-Site Request Forgery - 跨站请求伪造 2. ...

  7. 2018年最新JAVA面试题总结之基础(1)

    转自于:https://zhuanlan.zhihu.com/p/39322967 1.JAVA中能创建volatile数组吗?volatile能使得一个非原子操作变成原子操作吗? 回答: 能,Jav ...

  8. redis 实现

    /** * Returns a string containing the string representation of each of {@code parts}, using the * pr ...

  9. java-数组排序--冒泡排序、鸡尾酒排序、地精排序

    冒泡排序 冒泡排序的思想是,让依次数组中相邻的数进行比较,如果前一个数比后一个数大,则两数进行交换,大的数就会象泡泡一样慢慢浮在水面上了 见图解 稳定性:稳定时间复杂度:O(n2) public st ...

  10. 002 html总结

    1.题目 每个HTML文件里开头都有个很重要的东西,Doctype,知道这是干什么的吗? div+css的布局较table布局有什么优点? strong与em的异同? 你能描述一下渐进增强和优雅降级之 ...