zoukankan      html  css  js  c++  java
  • C 链表冒泡排序

    // LowQuikPoint.cpp : 定义控制台应用程序的入口点。
    //

    #include "stdafx.h"
    #include<iostream>

    using namespace std;

    typedef struct Node
    {
        struct Node * next;
        int data;
    }NODE;

    void showList(NODE* L)
    {
        if (L == nullptr)
            return;
        NODE* s = L->next;

        while (s!=nullptr)
        {
            cout << s->data << ",";
            s = s->next;
        }
    }

    void CreateList(NODE* &list)
    {
        int x = -1;
        NODE* p = list;
        if (nullptr == list) return;
        cin >> x;
        while (x != -1)
        {
            Node * n = new Node();
            n->data = x;

            p->next = n;
            p = n;
            cin >> x;
        }
        p->next = nullptr;
    }


    void DeleteList(Node * &header)

    {
        if (nullptr == header) return;

        Node * list = header;

        Node * p = header->next;

        while (list!=nullptr)
        {
            delete list;
            list = p;
            if (p  != nullptr)
                p = p->next;

        }
        header = nullptr;
    }

    Node * bubblySort(Node * &header)
    {
        if (header == nullptr || header->next == nullptr) return header;

        bool isChanger = true;
        Node *  p = nullptr;
        //冒泡大的向后,如果最后只有一个无须再排;如果上一次发现不有交换,说明已经有序,无须再排;
        while (p != header->next->next&& isChanger)
        {
            Node * q = header->next; isChanger = false;
            for (; q->next != nullptr &&q->next != p; q = q->next)
            {
                if (q->data>q->next->data)
                {
                    swap(q->data, q->next->data);
                    isChanger = true;
                }
            }
            p = q;
        }
        return header;
    }


    int _tmain(int argc, _TCHAR* argv[])
    {
        Node * L = new Node();

        CreateList(L);
         showList(L);
        cout << endl;
         bubblySort(L);
         showList(L);
        cout << endl;
         DeleteList(L);
        showList(L);
        return 0;
    }


  • 相关阅读:
    结对-结对编程项目作业名称-结对项目总结
    课后作业 -团队项目编程进度
    团队-象棋游戏-模块开发过程
    团队-象棋游戏-模块测试过程
    结队-结队编程项目作业名称-项目进度
    课后作业-阅读任务-阅读笔记-3
    团队-象棋游戏-需求分析
    团队-象棋游戏-成员简介及分工
    课后作业 -团队项目编程进度
    团队编程 象棋游戏 开发文档
  • 原文地址:https://www.cnblogs.com/sharecenter/p/14372469.html
Copyright © 2011-2022 走看看