C語言實現(xiàn)輸出鏈表中倒數(shù)第k個節(jié)點
本文實例展示了C++實現(xiàn)輸出鏈表中倒數(shù)第k個節(jié)點的方法,分享給大家供大家參考之用。
運行本文所述實例可實現(xiàn)輸入一個單向鏈表,輸出該鏈表中倒數(shù)第k個節(jié)點。
具體實現(xiàn)方法如下:
/* * Copyright (c) 2011 alexingcool. All Rights Reserved. */ #include <iostream> using namespace std; int array[] = {5, 7, 6, 9, 11, 10, 8}; const int size = sizeof array / sizeof *array; struct Node { Node(int i = 0, Node *n = NULL) : item(i), next(n) {} int item; Node *next; }; Node* construct(int (&array)[size]) { Node dummy; Node *head = &dummy; for(int i = 0; i < size; i++) { Node *temp = new Node(array[i]); head->next = temp; head = temp; } return dummy.next; } void print(Node *head) { while(head) { cout << head->item << " "; head = head->next; } } Node* findKnode(Node *head, int k) { Node *pKnode = head; if(head == NULL) { cout << "link is null" << endl; return NULL; } while(k--) { if(head == NULL) { cout << "k is bigger than the length of the link" << endl; return NULL; } head = head->next; } while(head) { head = head->next; pKnode = pKnode->next; } return pKnode; } void main() { Node *head = construct(array); cout << "source link: "; print(head); cout << endl; Node *kNode = findKnode(head, 5); if(kNode != NULL) cout << "the knode is: " << kNode->item << endl; }
測試用例如下:
1. NULL Link
head = NULL;
2. normal Link, with normal k
k <= len(head);
3. normal Link, with invalid k
k > len(head)
希望本文所述對大家C程序算法設(shè)計的學(xué)習(xí)有所幫助。
- C語言之雙向鏈表詳解及實例代碼
- C語言解字符串逆序和單向鏈表逆序問題的代碼示例
- C語言靜態(tài)鏈表和動態(tài)鏈表
- C語言創(chuàng)建和操作單鏈表數(shù)據(jù)結(jié)構(gòu)的實例教程
- C語言單鏈表的實現(xiàn)
- C語言之單鏈表的插入、刪除與查找
- C語言實現(xiàn)雙向鏈表
- C語言實現(xiàn)帶頭結(jié)點的鏈表的創(chuàng)建、查找、插入、刪除操作
- C語言實現(xiàn)單鏈表逆序與逆序輸出實例
- C語言單循環(huán)鏈表的表示與實現(xiàn)實例詳解
- c語言鏈表基本操作(帶有創(chuàng)建鏈表 刪除 打印 插入)
- C語言之單向鏈表詳解及實例代碼
相關(guān)文章
基于Windows API實現(xiàn)遍歷所有文件并刪除的方法
這篇文章主要介紹了基于Windows API實現(xiàn)遍歷所有文件并刪除的方法,是win32應(yīng)用程序的一個比較典型的文件操作應(yīng)用技巧,需要的朋友可以參考下2015-04-04詳解C語言隨機數(shù)設(shè)置的三種方式(保姆級教程)
本篇文章將為大家介紹在C語言中設(shè)置隨機數(shù)的三大方法的使用,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)C語言有一定的幫助,需要的可以參考一下2022-11-11詳解C語言中fseek函數(shù)和ftell函數(shù)的使用方法
這篇文章主要介紹了C語言中fseek函數(shù)和ftell函數(shù)的使用方法,兩個函數(shù)分別用于設(shè)置和返回文件指針stream的位置,需要的朋友可以參考下2016-03-03C++ LeetCode1945題解字符串轉(zhuǎn)化后的各位數(shù)字之和
這篇文章主要為大家介紹了C++ LeetCode1945題解字符串轉(zhuǎn)化后的各位數(shù)字之和示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12