C++中的一些注意點(part5)

來源:互聯網
上載者:User

#include<iostream>
#include<queue>
using namespace std;

struct Node{
 
 int a;
 Node* parent;
};
queue<Node> Queue;

int main(){
 
 Node array[4];
 for(int i=0;i<4;i++){
  
  array[i].a=i;
  if(i==0)
   array[i].parent=NULL;
  else
   array[i].parent=&array[i-1];
  Queue.push(array[i]);
 }
 
 Queue.pop();         //即使這裡使用pop操作,Node結構中的parent指標仍然是有效
 cout<<"Queue size="<<Queue.size()<<endl;
 Node tmp=array[3];
 while(tmp.parent!=NULL){
  
  cout<<tmp.a<<endl;
  tmp=*tmp.parent;       //"."運算子的優先順序高於"*"
 }
 
 cout<<"**********************"<<endl;
 Node t;
 t.a=5;
 t.parent=&array[3];
 Queue.push(t);
 
// while( ! Queue.empty()){
//  
//  cout<< (Queue.front()).a<<endl;
//  Queue.pop();
// }

 cout<<"**********************"<<endl;
 t.a=6;           //在Queue外部改變元素的值,容器內的元素不受影響
 t.parent=&array[2];
// while( ! Queue.empty()){
//  
//  cout<< (Queue.front()).a<<endl;
//  Queue.pop();
// }
 return 0;
}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.