排序算法

6 篇文章 0 订阅
2 篇文章 0 订阅


插入排序:

就像摸牌,摸一张插进去,找一个哨兵,从第二个开始,和前一个比较,小的话前移一位。

  1. #include <iostream>  
  2. #include<stdlib.h>  
  3.   
  4. using namespace std;  
  5. #define N 4   //不能加分号结束  
  6.   
  7. class sort  
  8. {  
  9. public:  
  10.     void insertSort(int a[],int n);  
  11.     sort()  
  12.     {  
  13.         cout<<"Start"<<endl;  
  14.     }  
  15.     sort(const sort&s);  
  16. private:  
  17.   
  18. };  
  19. void sort::insertSort(int a[],int n)  
  20. {  
  21.     int i=1,j=0,key;//设两个变量值的目的是内外变化,如果只有一个内外的变化会产生影响  
  22.     while(i<n)    //外循环  
  23.     {  
  24.         key=a[i];//把第几个拿出来,和前边的对比;  
  25.         j=i-1;   //前边的那个值  
  26.         while(key<a[j]&&j>=0)  //内循环  
  27.         {  
  28.             a[j+1]=a[j];   //把当前值改成前一个值  
  29.             j--;          //位置前移一位  
  30.         }  
  31.         a[j+1]=key;      //比较成功之后,把哨兵插到当前位置,注意用的是j  
  32.         i++;   //转到下次循环  
  33.     }  
  34.     cout<<"-----------\n ";  
  35.     for(int i=0;i<n;i++)  
  36.     {  
  37.         cout<<a[i];  
  38.     }  
  39. }  
  40. sort::sort(const sort&s)  
  41. {  
  42.     cout<<"news\n";  
  43. }  
  44. int main()  
  45. {  
  46.     sort s;  
  47.     //sort b=s;  
  48.     int a[N];  
  49.     cout<<"lease input arr.";  
  50.     for(int i=0;i<N;i++)  
  51.     {  
  52.         cin>>a[i];  
  53.     }  
  54.     cout<<"shuchu wei";  
  55.     for(int i=0;i<N;i++)  
  56.     {  
  57.         cout<<a[i]<<endl;  
  58.     }  
  59.     s.insertSort(a,N);  
  60.   
  61.     return 0;  
  62. };  
#include <iostream>
#include<stdlib.h>

using namespace std;
#define N 4   //不能加分号结束

class sort
{
public:
    void insertSort(int a[],int n);
    sort()
    {
        cout<<"Start"<<endl;
    }
    sort(const sort&s);
private:

};
void sort::insertSort(int a[],int n)
{
    int i=1,j=0,key;//设两个变量值的目的是内外变化,如果只有一个内外的变化会产生影响
    while(i<n)    //外循环
    {
        key=a[i];//把第几个拿出来,和前边的对比;
        j=i-1;   //前边的那个值
        while(key<a[j]&&j>=0)  //内循环
        {
            a[j+1]=a[j];   //把当前值改成前一个值
            j--;          //位置前移一位
        }
        a[j+1]=key;      //比较成功之后,把哨兵插到当前位置,注意用的是j
        i++;   //转到下次循环
    }
    cout<<"-----------\n ";
    for(int i=0;i<n;i++)
    {
        cout<<a[i];
    }
}
sort::sort(const sort&s)
{
    cout<<"news\n";
}
int main()
{
    sort s;
    //sort b=s;
    int a[N];
    cout<<"lease input arr.";
    for(int i=0;i<N;i++)
    {
        cin>>a[i];
    }
    cout<<"shuchu wei";
    for(int i=0;i<N;i++)
    {
        cout<<a[i]<<endl;
    }
    s.insertSort(a,N);

    return 0;
};

  1.   
 
 

冒泡排序

  1. #include<stdlib.h>  
  2.   
  3. using namespace std;  
  4. #define N 4   //不能加分号结束  
  5.   
  6. class sort  
  7. {  
  8. public:  
  9.     void insertSort(int a[],int n);  
  10.     sort()  
  11.     {  
  12.         cout<<"Start"<<endl;  
  13.     }  
  14.     sort(const sort&s);  
  15.     void bubblesort(int a[],int n);  
  16. private:  
  17.     int c;  
  18. };  
  19. void sort::insertSort(int a[],int n)  
  20. {  
  21.     int i=1,j=0,key;//设两个变量值的目的是内外变化,如果只有一个内外的变化会产生影响  
  22.     while(i<n)    //外循环  
  23.     {  
  24.         key=a[i];//把第几个拿出来,和前边的对比;  
  25.         j=i-1;   //前边的那个值  
  26.         while(key<a[j]&&j>=0)  //内循环  
  27.         {  
  28.             a[j+1]=a[j];   //把当前值改成前一个值  
  29.             j--;          //位置前移一位  
  30.         }  
  31.         a[j+1]=key;      //比较成功之后,把哨兵插到当前位置,注意用的是j  
  32.         i++;   //转到下次循环  
  33.     }  
  34.     cout<<"-----insertsort------\n ";  
  35.     for(int i=0;i<n;i++)  
  36.     {  
  37.         cout<<a[i];  
  38.     }  
  39.     cout<<endl;  
  40. }  
  41. void sort::bubblesort(int a[],int n)  
  42. {  
  43.     int i=0,j=n;  
  44.     for(;i<n-1;i++)//外层循环  
  45.     {  
  46.         for(;j>i;j--)//内层循环,从最后一个开始向上冒泡,冒泡次数逐渐减一  
  47.         {  
  48.             if(a[j]<a[j-1])//倒数开始,两个数进行比较,下边是交换过程  
  49.             {  
  50.                 int temp=a[j-1];  
  51.                 a[j-1]=a[j];  
  52.                 a[j]=temp;  
  53.             }  
  54.         }  
  55.     }  
  56.     cout<<"-----bubblesort------\n ";  
  57.     for(int i=0;i<n;i++)  
  58.     {  
  59.         cout<<a[i];  
  60.     }  
  61.     cout<<endl;  
  62. }  
  63. sort::sort(const sort&s)  
  64. {  
  65.     cout<<"news\n";  
  66. }  
  67. int main()  
  68. {  
  69.     sort s;  
  70.     //sort b=s;  
  71.     int a[N];  
  72.     cout<<"lease input arr.";  
  73.   
  74.     for(int i=0;i<N;i++)  
  75.     {  
  76.         cin>>a[i];  
  77.     }  
  78.     cout<<"shuchu wei";  
  79.     for(int i=0;i<N;i++)  
  80.     {  
  81.         cout<<a[i];  
  82.     }  
  83.     cout<<endl;  
  84.   
  85.     s.insertSort(a,N);  
  86.     s.bubblesort(a,N);  
  87.   
  88.     return 0;  
  89. };
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
完整版:https://download.csdn.net/download/qq_27595745/89522468 【课程大纲】 1-1 什么是java 1-2 认识java语言 1-3 java平台的体系结构 1-4 java SE环境安装和配置 2-1 java程序简介 2-2 计算机中的程序 2-3 java程序 2-4 java类库组织结构和文档 2-5 java虚拟机简介 2-6 java的垃圾回收器 2-7 java上机练习 3-1 java语言基础入门 3-2 数据的分类 3-3 标识符、关键字和常量 3-4 运算符 3-5 表达式 3-6 顺序结构和选择结构 3-7 循环语句 3-8 跳转语句 3-9 MyEclipse工具介绍 3-10 java基础知识章节练习 4-1 一维数组 4-2 数组应用 4-3 多维数组 4-4 排序算法 4-5 增强for循环 4-6 数组和排序算法章节练习 5-0 抽象和封装 5-1 面向过程的设计思想 5-2 面向对象的设计思想 5-3 抽象 5-4 封装 5-5 属性 5-6 方法的定义 5-7 this关键字 5-8 javaBean 5-9 包 package 5-10 抽象和封装章节练习 6-0 继承和多态 6-1 继承 6-2 object类 6-3 多态 6-4 访问修饰符 6-5 static修饰符 6-6 final修饰符 6-7 abstract修饰符 6-8 接口 6-9 继承和多态 章节练习 7-1 面向对象的分析与设计简介 7-2 对象模型建立 7-3 类之间的关系 7-4 软件的可维护与复用设计原则 7-5 面向对象的设计与分析 章节练习 8-1 内部类与包装器 8-2 对象包装器 8-3 装箱和拆箱 8-4 练习题 9-1 常用类介绍 9-2 StringBuffer和String Builder类 9-3 Rintime类的使用 9-4 日期类简介 9-5 java程序国际化的实现 9-6 Random类和Math类 9-7 枚举 9-8 练习题 10-1 java异常处理 10-2 认识异常 10-3 使用try和catch捕获异常 10-4 使用throw和throws引发异常 10-5 finally关键字 10-6 getMessage和printStackTrace方法 10-7 异常分类 10-8 自定义异常类 10-9 练习题 11-1 Java集合框架和泛型机制 11-2 Collection接口 11-3 Set接口实现类 11-4 List接口实现类 11-5 Map接口 11-6 Collections类 11-7 泛型概述 11-8 练习题 12-1 多线程 12-2 线程的生命周期 12-3 线程的调度和优先级 12-4 线程的同步 12-5 集合类的同步问题 12-6 用Timer类调度任务 12-7 练习题 13-1 Java IO 13-2 Java IO原理 13-3 流类的结构 13-4 文件流 13-5 缓冲流 13-6 转换流 13-7 数据流 13-8 打印流 13-9 对象流 13-10 随机存取文件流 13-11 zip文件流 13-12 练习题 14-1 图形用户界面设计 14-2 事件处理机制 14-3 AWT常用组件 14-4 swing简介 14-5 可视化开发swing组件 14-6 声音的播放和处理 14-7 2D图形的绘制 14-8 练习题 15-1 反射 15-2 使用Java反射机制 15-3 反射与动态代理 15-4 练习题 16-1 Java标注 16-2 JDK内置的基本标注类型 16-3 自定义标注类型 16-4 对标注进行标注 16-5 利用反射获取标注信息 16-6 练习题 17-1 顶目实战1-单机版五子棋游戏 17-2 总体设计 17-3 代码实现 17-4 程序的运行与发布 17-5 手动生成可执行JAR文件 17-6 练习题 18-1 Java数据库编程 18-2 JDBC类和接口 18-3 JDBC操作SQL 18-4 JDBC基本示例 18-5 JDBC应用示例 18-6 练习题 19-1 。。。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值