程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> 關於C++ >> C++實現打印兩個有序鏈表公共部分的方法

C++實現打印兩個有序鏈表公共部分的方法

編輯:關於C++

C++實現打印兩個有序鏈表公共部分的方法。本站提示廣大學習愛好者:(C++實現打印兩個有序鏈表公共部分的方法)文章只能為提供參考,不一定能成為您想要的結果。以下是C++實現打印兩個有序鏈表公共部分的方法正文


C++實現打印兩個有序鏈表公共部分的方法

作者:難免有錯_

這篇文章主要介紹了C++實現打印兩個有序鏈表公共部分的方法,涉及C++針對有序鏈表的簡單遍歷、比較相關操作技巧,需要的朋友可以參考下

本文實例講述了C++實現打印兩個有序鏈表公共部分的方法。分享給大家供大家參考,具體如下:

題目:

給定兩個有序鏈表的頭指針head1和head2,打印兩個鏈表的公共部分。

解題思路及代碼:

1、head1的值小於head2,則head1往下移動
2、head1的值小於head2,則head2往下移動
3、相等則打印任何一個鏈表節點的值,head1和head2都往下移動。
4、當head1或head2移動到NULL,終止。

算法C++代碼:

typedef struct Node
{
  int data;
  struct Node* next;
}node, *pLinkedlist;
void printCommomElem(pLinkedlist head1, pLinkedlist head2)
{
  cout << "print commom elements: " << endl;
  while (head1->next != NULL && head2->next != NULL)
  {
    if (head1->data < head2->data)
      head1 = head1->next;
    else if (head1->data > head2->data)
      head2 = head2->next;
    else
    {
      cout << head1->data << " ";
      head1 = head1->next;
      head2 = head2->next;
    }
  }
  cout << endl;
}

希望本文所述對大家C++程序設計有所幫助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved