欧美大屁股bbbbxxxx,狼人大香伊蕉国产www亚洲,男ji大巴进入女人的视频小说,男人把ji大巴放进女人免费视频,免费情侣作爱视频

歡迎來(lái)到入門(mén)教程網(wǎng)!

C語(yǔ)言

當(dāng)前位置:主頁(yè) > 軟件編程 > C語(yǔ)言 >

C++鏈表倒序?qū)崿F(xiàn)方法

來(lái)源:本站原創(chuàng)|時(shí)間:2020-01-10|欄目:C語(yǔ)言|點(diǎn)擊: 次

本文通過(guò)一個(gè)實(shí)例展示了C++實(shí)現(xiàn)鏈表倒序的方法,對(duì)于C++數(shù)據(jù)結(jié)構(gòu)的學(xué)習(xí)有很好的參考借鑒價(jià)值。具體方法如下:

首先,C++鏈表倒序的難點(diǎn)在于如何一個(gè)個(gè)地修改。雖然不是數(shù)組,但是大概思想是一樣的,所以可以用一個(gè)for循序,一個(gè)游標(biāo)對(duì)應(yīng)for循環(huán)里面的 i,只不過(guò)要記得前一個(gè)節(jié)點(diǎn)和后一個(gè)節(jié)點(diǎn),尤其是后一個(gè),因?yàn)樾薷闹缶驮L(fǎng)問(wèn)不到后面的,所以要記錄。for每一個(gè)循環(huán)只改變所指向的那個(gè)節(jié)點(diǎn)的指針,這樣既不會(huì)亂套了。

用一個(gè)for循環(huán)就非常好理解了,實(shí)例代碼如下所示:

#include <iostream>
#include <cstdlib>
#include <ctime>

using namespace std;

//鏈表節(jié)點(diǎn)類(lèi)
class Node
{
private:
  int m_data;
  Node* m_next;

  Node(Node&) {}    //copy constructor is not allowed

public:
  explicit Node(int val = 0) : m_data(val), m_next(NULL) {}
  int getData() const { return m_data; }
  void setData(int val) { m_data = val; }
  Node* getNext(void) const { return m_next; }
  void setNext(Node* p) { m_next = p; }
};

//鏈表
class MyList
{
private:
  Node* m_head;  //pionter to the first node of the list
  Node* m_tail;  //poinoer to the last node of the list

  MyList(MyList&) {}
public:
  explicit MyList() : m_head(NULL), m_tail(NULL) {}
  void addNode(Node* pNode);
  void show(void) const;
  void reverse(void);
  void clean(void);
};

void MyList::addNode(Node* pNode)
{
  if (m_head)
  {
    m_tail->setNext(pNode);
    m_tail = pNode;
  }
  else    //blank list
  {
    m_head = pNode;
    m_tail = pNode;
  }
}

void MyList::show(void) const
{
  Node* pNode = m_head;
  while (pNode)
  {
    std::cout << pNode->getData() << "  ";
    pNode = pNode->getNext();
  }
}

void MyList::reverse(void)
{
  Node* preNode = NULL;    //下面游標(biāo)的前一個(gè)
  Node* pNode ;    //指向每一個(gè)節(jié)點(diǎn),相當(dāng)于游標(biāo)
  Node* afterNode;    //上面游標(biāo)的上一個(gè)

  for (pNode = m_head; pNode != NULL; pNode = afterNode)  //這里的每次循環(huán)對(duì)應(yīng)一個(gè)節(jié)點(diǎn),本質(zhì)上和數(shù)組原理差不多
  {
    afterNode = pNode->getNext();
    pNode->setNext(preNode);
    preNode = pNode;
  }

  pNode = m_head;  //交換頭尾指針
  m_head = m_tail;
  m_tail = pNode;
}

void MyList::clean(void)
{
  if (m_head)
  {
    Node* pNode = m_head;
    Node* pTemp;
    while (pNode)
    {
      pTemp = pNode->getNext();
      delete pNode;
      pNode = pTemp;
    }

    m_head = m_tail = NULL;
  }
}

int main(void)
{
  MyList listHead;

  srand((unsigned)time(NULL));
  for (int i = 0; i < 9; i++)
  {
    int temp = rand() % 50;
    Node* pNode = new Node(temp);
    listHead.addNode(pNode);
  }
  listHead.show();

  listHead.reverse();
  cout << endl;
  listHead.show();
  listHead.clean();
  listHead.show();
  
  system("pause");
}

相信本文實(shí)例對(duì)大家學(xué)習(xí)C++數(shù)據(jù)結(jié)構(gòu)與算法能起到一定的參考借鑒作用。

上一篇:C語(yǔ)言實(shí)現(xiàn)字符串匹配KMP算法

欄    目:C語(yǔ)言

下一篇:C++友元(Friend)用法實(shí)例簡(jiǎn)介

本文標(biāo)題:C++鏈表倒序?qū)崿F(xiàn)方法

本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/3465.html

網(wǎng)頁(yè)制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語(yǔ)言數(shù)據(jù)庫(kù)服務(wù)器

如果侵犯了您的權(quán)利,請(qǐng)與我們聯(lián)系,我們將在24小時(shí)內(nèi)進(jìn)行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有