<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 18,  comments - 1,  trackbacks - 0


    #include<iostream>
    using namespace std;
    typedef int T;

    class Node{
    ????? T data;
    ????? Node *next;
    public:
    ?????? Node(T t):data(t),next(NULL){}
    ?????? friend class List;?????
    ?????? };
    ?????
    class List{
    ????? Node * head;
    ????? int len;
    public:
    ??????? List(int len=0):len(len),head(NULL){}
    ??????? ~List(){clear();}
    ??????? Node* & getp( int pos ); 
    ??????? void insert( T d, int pos=0 );//插入
    ??????? int size();
    ??????? bool empty();
    ?????? ?void travel();//遍歷
    ????????void clear();
    ??????? int find( T d );//查找
    ??????? bool update( T d1, T d2 );//更新
    ??????? bool erase( T d );//刪除
    ??????? T getHead();
    ??????? T getTail();
    ??????? void reverse();
    ????? };
    void List::insert(T d,int pos){
    ???? Node *p=new Node(d);
    ???? Node *&pn=getp(pos);
    ???? p->next=pn;
    ???? pn=p;
    ???? ++len;
    ???? }
    ????
    Node*& List::getp(int pos){//返回一個引用而不是一個復制的數(shù)據(jù)
    ???? if(pos<0||pos>len)
    ??????????? pos=len;??????????????????
    ???? if(pos==0)
    ???????????? return head;
    ?????? Node*p=head;?????
    ???? for(int i=0;i<pos-1;i++)
    ??????????? p=p->next;
    ???? return p->next;
    ???? }
    int List::size(){
    ??? return len;
    ??? }
    bool List::empty(){
    ???? return head==NULL;
    ???? }?
    ??????
    void List::clear(){
    ????? while(head!=NULL){
    ???? Node *p =head->next;
    ???? delete head;
    ???? head=p;
    ???? }??
    ???? len=0 ;???????????????
    ???? }
    void List::travel(){
    ???? Node*p=head;
    ???? while(p!=NULL){
    ???? cout<<p->data<<' ';
    ???? p=p->next;??????????????
    ???? }
    ???? cout<<endl;??
    ???? }
    int List::find( T d ){
    ???? Node*p=head;
    ???? int pos=0;
    ????
    ???? while(p!=NULL){
    ??????? if(d==p->data)
    ??????????? return pos;
    ??????? p=p->next;
    ??????? ++pos;???????????????
    ???? }????
    ?????????? return -1;
    ???? }
    bool List::update( T d1, T d2 ){
    ???? int t=find(d1);
    ???? if(t==-1)
    ?????? return false;
    ???? Node*&p=getp(t);
    ???? p->data=d2;
    ???? return true;
    ???? }
    bool List:: erase(T d){
    ???? int t=find(d);
    ???? if(t==-1)
    ?????? return false;
    ????? Node*&pn=getp(t);
    ????? Node*p=pn;
    ????? pn=pn->next;
    ????? delete p;
    ????? --len;?????
    ???? return true;
    ???? }
    ?void List:: reverse(){
    ????? Node *ph=head;
    ????? Node *p=NULL;
    ????? head=NULL;
    ????? while(ph!=NULL){
    ??????? p=ph;
    ??????? ph=ph->next;
    ???????
    ??????? p->next=head;
    ??????? head=p;
    ???? }
    ????
    ????? }
    ?????
    T List::getHead(){
    ????? if(empty())
    ????????? return T();??????????
    ??????? return head->data;?????????
    ????? }
    T? List::getTail(){
    ????? if(empty())
    ?????????? return T();
    ?????? return getp(len-1)->data;????????????
    ????? }
    int main(){
    ??? List obj;
    ?obj.reverse();
    ?obj.travel();
    ?obj.insert(1,-1);
    ?obj.insert(2,-1);
    ?obj.insert(3,-1);
    ?obj.insert(4,-1);
    ?obj.insert(5);
    ?obj.insert(6);
    ?obj.insert(7);
    ?obj.insert(8);
    ?obj.insert(60,6);
    ?obj.insert(40,4);
    ?obj.insert(20,2);
    ?obj.travel();
    ?obj.reverse();
    ?obj.travel();
    ??? cout<<obj.find(60)<<endl;
    ?obj.update(20,600);
    ?obj.travel();
    ?obj.erase(600);
    ?obj.travel();
    ?cout<<obj.getHead()<<' '<<obj.getTail()<<endl;
    ?int t;
    ?cin>>t;
    ?return 0;
    ??? }

    posted on 2007-01-23 21:59 sunny 閱讀(182) 評論(0)  編輯  收藏

    只有注冊用戶登錄后才能發(fā)表評論。


    網(wǎng)站導航:
     
    <2007年1月>
    31123456
    78910111213
    14151617181920
    21222324252627
    28293031123
    45678910

    常用鏈接

    留言簿(1)

    隨筆分類

    隨筆檔案

    相冊

    收藏夾

    朋友

    搜索

    •  

    最新評論

    評論排行榜

    主站蜘蛛池模板: 亚洲AV永久无码精品一百度影院| 女人18毛片水真多免费看 | 久草视频在线免费| 亚洲av无码专区在线播放| 成人毛片100免费观看| 亚洲熟女一区二区三区| 中文在线观看免费网站| 亚洲国产精品无码久久一区二区| 久久精品成人免费网站| 亚洲精品高清视频| 免费人成在线观看69式小视频| 亚洲日本香蕉视频| 成年女性特黄午夜视频免费看| 亚洲人成人网站18禁| 国产成人综合久久精品免费| 一本久久免费视频| 国产亚洲精品美女久久久| 无码国产精品一区二区免费16 | 国产黄色片在线免费观看| 亚洲av乱码中文一区二区三区| 四虎永久免费观看| 久久免费观看视频| 亚洲av无码潮喷在线观看| 免费看成人AA片无码视频羞羞网| 亚洲AV成人一区二区三区在线看| 内射无码专区久久亚洲| 免费无码又爽又刺激网站| 亚洲另类图片另类电影| 日韩中文无码有码免费视频| 精品国产免费人成网站| 精品亚洲麻豆1区2区3区| 国产精品免费看久久久无码| a级毛片在线视频免费观看| 亚洲国产一区在线观看| 亚洲色图综合在线| 日本亚洲免费无线码| WWW国产成人免费观看视频| 亚洲高清美女一区二区三区| 午夜一区二区免费视频| 免费国产污网站在线观看| 亚洲欧美成人综合久久久|