C語(yǔ)言實(shí)現(xiàn)輸出鏈表中倒數(shù)第k個(gè)節(jié)點(diǎn)
本文實(shí)例展示了C++實(shí)現(xiàn)輸出鏈表中倒數(shù)第k個(gè)節(jié)點(diǎn)的方法,分享給大家供大家參考之用。
運(yùn)行本文所述實(shí)例可實(shí)現(xiàn)輸入一個(gè)單向鏈表,輸出該鏈表中倒數(shù)第k個(gè)節(jié)點(diǎn)。
具體實(shí)現(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;
}
測(cè)試用例如下:
1. NULL Link
head = NULL;
2. normal Link, with normal k
k <= len(head);
3. normal Link, with invalid k
k > len(head)
希望本文所述對(duì)大家C程序算法設(shè)計(jì)的學(xué)習(xí)有所幫助。
- C語(yǔ)言之雙向鏈表詳解及實(shí)例代碼
- C語(yǔ)言解字符串逆序和單向鏈表逆序問(wèn)題的代碼示例
- C語(yǔ)言靜態(tài)鏈表和動(dòng)態(tài)鏈表
- C語(yǔ)言創(chuàng)建和操作單鏈表數(shù)據(jù)結(jié)構(gòu)的實(shí)例教程
- C語(yǔ)言單鏈表的實(shí)現(xiàn)
- C語(yǔ)言之單鏈表的插入、刪除與查找
- C語(yǔ)言實(shí)現(xiàn)雙向鏈表
- C語(yǔ)言實(shí)現(xiàn)帶頭結(jié)點(diǎn)的鏈表的創(chuàng)建、查找、插入、刪除操作
- C語(yǔ)言實(shí)現(xiàn)單鏈表逆序與逆序輸出實(shí)例
- C語(yǔ)言單循環(huán)鏈表的表示與實(shí)現(xiàn)實(shí)例詳解
- c語(yǔ)言鏈表基本操作(帶有創(chuàng)建鏈表 刪除 打印 插入)
- C語(yǔ)言之單向鏈表詳解及實(shí)例代碼
相關(guān)文章
C語(yǔ)言代碼實(shí)現(xiàn)簡(jiǎn)單三子棋游戲
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言代碼實(shí)現(xiàn)簡(jiǎn)單三子棋游戲,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07
C++前綴樹(shù)字典樹(shù)的學(xué)習(xí)與模擬實(shí)現(xiàn)代碼示例
這篇文章主要介紹了C++前綴樹(shù)字典樹(shù)的學(xué)習(xí)與模擬實(shí)現(xiàn)代碼示例,Trie又被稱(chēng)為前綴樹(shù)、字典樹(shù),所以當(dāng)然是一棵樹(shù),上面這棵Trie樹(shù)包含的字符串集合是{in,inn,int,tea,ten,to},每個(gè)節(jié)點(diǎn)的編號(hào)是我們?yōu)榱嗣枋龇奖慵由先サ?需要的朋友可以參考下2023-07-07
對(duì)比C語(yǔ)言中execv相關(guān)的執(zhí)行文件的三個(gè)函數(shù)
這篇文章主要介紹了對(duì)比C語(yǔ)言中execv相關(guān)的執(zhí)行文件的三個(gè)函數(shù),分別為execv()函數(shù)和execve()函數(shù)以及execvp()函數(shù),需要的朋友可以參考下2015-08-08

