内容简介:简单的思路,就是首先交换但是
基本思路
简单的思路,就是首先交换 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变量与变量作用域
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Python编程无师自通
[美] 科里·奥尔索夫(Cory Althoff) / 宋秉金 / 人民邮电出版社 / 2019-1-1 / 59
畅销Python编程类入门书,美国亚马逊Kindle编程类排行榜榜一。 作者从文科毕业,通过自学编程转行为专业程序员,在硅谷工作多年后成功技术创业。本书不仅教读者如何使用Python语言编程,还会介绍其他书中所忽略的、编程初学者应该了解并掌握的其他所有知识点。 本书作者是一名自学成才的程序员,经过一年的自学,掌握了编程技能并在eBay找到了一份软件工程师的工作。本书是作者结合个人经验写......一起来看看 《Python编程无师自通》 这本书的介绍吧!