#include <iostream> using namespace std; struct Node{ int data; Node* next; }; Node* makeLinkedList(int n) { Node* allNode = new Node[n]; for(int i = 0; i < n; i++) { allNode[i].next = &allNode[i+1]; allNode[i].data = i + 1; if (i == n - 1) { allNode[n-1].next = NULL; } } return &allNode[0]; } void printLinkedList(Node* head) { while(head){ cout << head->data << endl; head = head->next; } } Node* reverse(Node* head) { Node* newhead = NULL; Node* left = head; while(left) { if (!newhead) { newhead = left; left = left->next; newhead->next = NULL; continue; } Node* top = left; left = left->next; top->next = newhead; newhead = top; } return newhead; } Node* reverseByNStep(Node* head, int n) { Node *unreversed = NULL; Node *reversing = NULL; Node *reversingTail = NULL; Node *reversed = NULL; Node* ret = NULL; // place all to unreversed unreversed = head; while(unreversed) { // split unreversed to two parts - reversing and unreversed reversing = unreversed; reversingTail = NULL; for(int i = 0; i < n; i++) { if(!unreversed) break; else reversingTail = unreversed; // shrink the unreversed unreversed = unreversed->next; } if (reversingTail) reversingTail->next = NULL; // reverse the reversing segment // and get the reversed segment's head and tail Node* segTail = reversing; Node* segHead = reverse(reversing); // the first reversed segment should save the returned head if (!reversed) { ret = segHead; } else { // for second+ segments // join the reversed part with segment head reversed->next = segHead; } // join the segment tail with the unreversed part segTail->next = unreversed; // expand the reversed part reversed = segTail; } // return final result return ret; } int main() { Node* head = makeLinkedList(10); printLinkedList(head); Node* r = reverseByNStep(head, 5); printLinkedList(r); }