内容简介:简单的思路,就是首先交换但是
基本思路
简单的思路,就是首先交换 root->next
和 revert_root
的指向,此时已经逆置了一个元素
但是 root
和 revert_root
就反了,再交换下就 ok 了
直接上代码
/* Author: SpringHack - springhack@live.cn Last modified: 2019-04-02 01:32:40 Filename: main.c Description: Created by SpringHack using vim automatically. */ #include <stdio.h> #include <stdlib.h> #include <string.h> // Test data int test_data[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }; // Node struct typedef struct _node { int value; struct _node* next; } node_item; // Just easy to use malloc typedef node_item* node; // Define linked list root and reverted linked list root // Only two variables needed to revert a linked list static node root = NULL; static node revert_root = NULL; int main() { // Create linked list { int i = 0, count = sizeof(test_data) / sizeof(int); node tmp; while (i < count) { if (!root) { root = (node)malloc(sizeof(node_item)); tmp = root; } else { tmp->next = (node)malloc(sizeof(node_item)); tmp = tmp->next; } tmp->next = NULL; tmp->value = test_data[i]; ++i; } } // Print linked list { node tmp = root; while (tmp) { printf(tmp->next ? "%d " : "%d", tmp->value); tmp = tmp->next; } printf("\n"); } // Revert linked list { while (root) { if (!revert_root) { revert_root = root; root = root->next; revert_root->next = NULL; } else { revert_root = (node)((intptr_t)revert_root ^ (intptr_t)root->next); root->next = (node)((intptr_t)revert_root ^ (intptr_t)root->next); revert_root = (node)((intptr_t)revert_root ^ (intptr_t)root->next); revert_root = (node)((intptr_t)revert_root ^ (intptr_t)root); root = (node)((intptr_t)revert_root ^ (intptr_t)root); revert_root = (node)((intptr_t)revert_root ^ (intptr_t)root); } } } // Print reverted linked list { node tmp = revert_root; while (tmp) { printf(tmp->next ? "%d " : "%d", tmp->value); tmp = tmp->next; } printf("\n"); } return 0; }
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- Directory Opus应用:重新打包群星存档
- Python对接企业微信会话内容存档功能的实践
- Versity 开源 ScoutFS 存档文件系统,可储存1万亿文件
- Versity 开源 ScoutFS 存档文件系统,可储存1万亿文件
- 全局变量,静态全局变量,局部变量,静态局部变量
- python变量与变量作用域
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
深入浅出Ext JS
何启伟、徐会生、康爱媛 / 人民邮电出版社 / 2010-5 / 69.00元
以用户为中心的时代,应用的界面外观变得越来越重要。然而,很多程序员都缺乏美术功底,要开发出界面美观的应用实属不易。Ext JS的出现,为广大程序员解决了这一难题。它有丰富多彩的界面和强大的功能,是开发具有炫丽外观的RIA应用的最佳选择。 本书是《深入浅出Ext JS》的升级版,涵盖了最新发布的Ext JS 3.2新特性,并对上一版的内容进行增补,充实了示例代码,同时补充了两个功能强大的实例。......一起来看看 《深入浅出Ext JS》 这本书的介绍吧!