史上最简单的C语言链表实现,没有之一
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define NR(x) (sizeof(x)/sizeof(x[0]))
struct node
{
int data ;
struct node *next ;
};
void top_append_list(struct node *head , int value);
void print_link(struct node head);
void tail_append_list(struct node *head , int value);
int delete_link_node(struct node *head , int number);
int sort_link_node(struct node *head , int flag ); //flag = 1 s->b 0 b->s
void turn_over_node(struct node *head);
int main(void)
{
int array[] = {1,2,5,4,3,8,7,6,9};
struct node head = {.next = NULL} ;
struct node *headp ;
int i ;
for(i = 0 ; i < NR(array) ; i++)
{
tail_append_list(&head , array[i]);
}
print_link(head);
int num ;
sort_link_node(&head , 1);
print_link(head);
//b -> s
sort_link_node(&head , 0);
print_link(head);
turn_over_node(&head);
print_link(head);
return 0 ;
}
void top_append_list(struct node *head , int value)
{
struct node *New = NULL ;
New = malloc(sizeof(struct node));
if(NULL == New){
fprintf(stderr , "分配失败!\n");
return ;
}
New->data = value ;
New->next = head->next ;
head->next = New ;
}
void print_link(struct node head)
{
struct node *tmp = head.next ;
while(tmp)
{
printf("%d " , tmp->data);
tmp = tmp->next ;
}
putchar('\n');
}
void tail_append_list(struct node *head , int value)
{
struct node *New = NULL ;
New = malloc(sizeof(struct node ));
if(NULL == New){
fprintf(stderr , "分配失败!\n");
return ;
}
New->data = value ;
struct node *tmp = head ;
while(tmp->next && (tmp = tmp->next)) ;
New->next = tmp->next ;
tmp->next = New ;
}
int delete_link_node(struct node *head , int number)
{
struct node *after = head->next , *before = head;
int flag = 0 ;
while(after)
{
if(after->data == number)
{
flag = 1 ;
before->next = after->next ;
after->next = NULL ;
free(after);
after = before->next ;
continue ;
}
after = after->next;
before = before->next ;
}
return flag ;
}
int sort_link_node(struct node *head , int flag ) //flag = 1 s->b 0 b->s
{
int tmp ;
struct node *tmp1 , *tmp2 ;
tmp1 = head ;
while(tmp1 = tmp1->next)
{
tmp2 = tmp1->next ;
while(tmp2)
{
if((flag==1)?(tmp1->data > tmp2->data):(tmp1->data < tmp2->data))
{
memcpy(&tmp , &tmp1->data , sizeof(int));
memcpy(&tmp1->data , &tmp2->data , sizeof(int));
memcpy(&tmp2->data , &tmp , sizeof(int));
}
tmp2 = tmp2->next ;
}
}
}
void turn_over_node(struct node *head)
{
struct node *tmp = head->next ;
struct node *cur = NULL;
head->next = NULL ;
while(cur = tmp)
{
tmp = tmp->next ;
cur->next = head->next ;
head->next = cur ;
}
}
史上最简单的C语言链表实现,没有之一的更多相关文章
- 史上最简单,一步集成侧滑(删除)菜单,高仿QQ、IOS。
重要的话 开头说,not for the RecyclerView or ListView, for the Any ViewGroup. 本控件不依赖任何父布局,不是针对 RecyclerView. ...
- [分享] 史上最简单的封装教程,五分钟学会封装系统(以封装Windows 7为例)
[分享] 史上最简单的封装教程,五分钟学会封装系统(以封装Windows 7为例) 踏雁寻花 发表于 2015-8-23 23:31:28 https://www.itsk.com/thread-35 ...
- 史上最简单的 SpringCloud 教程
史上最简单的 SpringCloud 教程 | 第一篇: 服务的注册与发现(Eureka)史上最简单的SpringCloud教程 | 第二篇: 服务消费者(rest+ribbon)史上最简单的Spri ...
- 史上最简单的 SpringCloud 教程 | 终章
https://blog.csdn.net/forezp/article/details/70148833转载请标明出处:http://blog.csdn.net/forezp/article/det ...
- 史上最简单的 GitHub 教程
史上最简单的 GitHub 教程 温馨提示:本系列博文已经同步到 GitHub,如有需要的话,欢迎大家到「github-tutorial」进行Star和Fork操作! 1 简介 GitHub 是一个面 ...
- (转) 史上最简单的 SpringCloud 教程 | 第一篇: 服务的注册与发现(Eureka)
一.spring cloud简介 spring cloud 为开发人员提供了快速构建分布式系统的一些工具,包括配置管理.服务发现.断路器.路由.微代理.事件总线.全局锁.决策竞选.分布式会话等等.它运 ...
- 史上最简单的SpringCloud教程 | 第十篇: 高可用的服务注册中心(Finchley版本)
转载请标明出处: 原文首发于 https://www.fangzhipeng.com/springcloud/2018/08/30/sc-f10-eureka/ 本文出自方志朋的博客 文章 史上最简单 ...
- 史上最简单的 MySQL 教程(十五)「列属性 之 自动增长」
自动增长 自动增长:auto_increment,当对应的字段,不给值,或者是默认值,或者是null的时候,就会自动的被系统触发,系统会从当前字段中取已有的最大值再进行+1操作,得到新的字段值. 自增 ...
- 史上最简单的 SpringCloud 教程 | 第一篇: 服务的注册与发现Eureka(Finchley版本)
转载请标明出处: 原文首发于:https://www.fangzhipeng.com/springcloud/2018/08/30/sc-f1-eureka/ 本文出自方志朋的博客 一.spring ...
随机推荐
- Spring整合DWR comet 实现无刷新 多人聊天室
用dwr的comet(推)来实现简单的无刷新多人聊天室,comet是长连接的一种.通常我们要实现无刷新,一般会使用到Ajax.Ajax 应用程序可以使用两种基本的方法解决这一问题:一种方法是浏览器每隔 ...
- 2.Lucene3.6.2包介绍,第一个Lucene案例介绍,查看索引信息的工具lukeall介绍,Luke查看的索引库内容,索引查找过程
1 Lucen目录介绍 2 lucene-core-3.6.2.jar是lucene开发核心jar包 contrib 目录存放,包含一些扩展jar包 3 案例 建立第一个Lucene项目 ...
- 15 Action View 以及监听 的使用
menu 代码 <menu xmlns:android="http://schemas.android.com/apk/res/android" > <!-- a ...
- linux中Cron定时任务系统命令详解
分类:Linux VPS教程 作者:阿川 发布时间:October 13, 2011 有很多同学在购买VPS之后,需要用到计划任务.但是又对计划任务不太了解,所以.今天我们的帮助中心主要是给大家提供一 ...
- Cocos2D v3.4.9粒子效果不能显示的原因分析及解决办法
大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 在游戏App中为了衬托气氛我们往往使用一些特殊的图形效果,粒子 ...
- Cocos2D两个方法的重构一例
大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 在RPG游戏项目的GameSpace类中原来有一个方法: -( ...
- 一个ExtJS实例
聊聊ExtJS 这几天接触了一个项目 前台用的是extjs 发现这个东西还是有点意思的 就把前台的部分 剥离了下来 有兴趣的朋友可以当做模板学习 不多说先上效果图 这篇文章 可以看作是ext知识的一 ...
- 07 ProgressDialog
<span style="font-size:18px;">package com.fmy.example1; import android.app.Activity; ...
- Asp.net实现下拉框和列表框的连动
走过了牛腩老师的新闻发布系统,漫游过了孙鑫老师的Html,在427沐浴第一缕冬日阳光的美丽月底,小编迎来了北大青鸟的Asp.net,北大青鸟,高大上的赶脚有么有,哈哈哈,开始了小编的.net之旅. 首 ...
- iOS平台添加Google Admob -1/2(Unity3D开发之七)
猴子原创,欢迎转载.转载请注明: 转载自Cocos2D开发网–Cocos2Dev.com,谢谢! 原文地址: http://www.cocos2dev.com/?p=567 Unity调用iOS还是非 ...