• 手机版

    扫码体验手机版

  • 微信公众号

    扫码关注公众号

国内首家协议开发

软芯音视解码保护平台

在线
客服

发布
需求

在线
聊天

天盟
APP

天盟APP下载

关注
微信

微信扫一扫访问
顶部

求问使用智能指针双链表的插入排序问题

//Implment insertion sort using smart pointers.
//You are not allowed to swap node values; instead, you are only
//allowed to change pointer addresses.






#include
#include
using namespace std;


class node {
public:
        int value;
        //node * next;
        //node * previous;
        shared_ptr next;
        weak_ptr previous;
        //node(int i) { value = i; next = previous = nullptr; }
        node(int i) { value = i; }
        //node() { next = previous = nullptr; }
        node() {}
};


class doubly_linked_list {
public:
        //node * head;
        //node * tail;
        shared_ptr head, tail;
        //doubly_linked_list() { head = tail = nullptr; }
        doubly_linked_list() {}
        void make_random_list(int m, int n);
        void print_forward();
        void print_backward();
       
        //***************************
        //You need to implement insertion_sort following the
        //special requirements.
        void insertion_sort();
};


void doubly_linked_list::make_random_list(int m, int n) {


        for (int i = 0; i < m; i++) {
                //node * p1 = new node(rand() % n);
                shared_ptr p1 = make_shared(rand() % n);
                p1->previous = tail;
                //if (tail != nullptr ) tail->next = p1;
                if (tail) tail->next = p1;
                tail = p1;
                //if (head == nullptr) head = p1;
                if (!head) head = p1;
        }
}


void doubly_linked_list::print_forward() {

        cout

免责声明:本内容仅代表回答会员见解不代表天盟观点,请谨慎对待。

版权声明:作者保留权利,不代表天盟立场。

使用道具 举报

发新帖

发布任务需求已有1031167位用户正在使用天盟网服务

发布分类: *
任务预算: *
需求内容: *
手机号码: *
任务商家报价为
  • 预算价 :
  • 成交价 :
  • 完工期 :
  • 质保期 :

* 最终任务项目以服务商报价、双方协商为准!