c语言双链表iterator,C语言使用utlist实现的双向链表

#include

#include

#include

#include "utlist.h"

#define BUFLEN 20

typedef struct el {

char bname[BUFLEN];

struct el *next, *prev;

} el;

int namecmp(el *a, el *b) {

return strcmp(a->bname,b->bname);

}

el *head = NULL; /* important- initialize to NULL! */

int main(int argc, char *argv[]) {

el *name, *elt, *tmp, etmp;

char linebuf[BUFLEN];

int count;

FILE *file;

if ( (file = fopen( "test11.dat", "r" )) == NULL ) {

perror("can't open: ");

exit(-1);

}

while (fgets(linebuf,BUFLEN,file) != NULL) {

if ( (name = (el*)malloc(sizeof(el))) == NULL) exit(-1);

strncpy(name->bname,linebuf,BUFLEN);

DL_APPEND(head, name);

}

DL_SORT(head, namecmp);

DL_FOREACH(head,elt) printf("%s", elt->bname);

DL_COUNT(head, elt, count);

printf("%d number of elements in list\n", count);

memcpy(&etmp.bname, "WES\n", 5);

DL_SEARCH(head,elt,&etmp,namecmp);

if (elt) printf("found %s\n", elt->bname);

/* now delete each element, use the safe iterator */

DL_FOREACH_SAFE(head,elt,tmp) {

DL_DELETE(head,elt);

}

fclose(file);

return 0;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值