简单排序算法 C++类实现
简单排序算法:
- 冒泡排序
- 插入排序
- 选择排序
.h代码:
//
// SortClass.h
// sort and selection
//
// Created by wasdns on 16/10/8.
// Copyright © 2016年 wasdns. All rights reserved.
//
#ifndef SortClass_h
#define SortClass_h
class Array {
private:
int *a;
int n;
public:
Array(int a = 0):n(a){};
void Initial(int n); //数组初始化
void SelectSort(); //选择排序
void BubbleSort(); //冒泡排序
void InsertSort(); //插入排序
void PrintArray(); //输出数组
};
#endif /* SortClass_h */
.cpp代码:
//
// Implementation.cpp
// sort and selection
//
// Created by wasdns on 16/10/8.
// Copyright © 2016年 wasdns. All rights reserved.
//
#include <stdio.h>
#include <iostream>
#include <cstdlib>
#include "SortClass.h"
using namespace std;
/*
* 函数名称:SwapNum
* 函数参数:整形指针p, 交换位置l,交换位置r
* 函数目的:交换*(p+l)与*(p+r)
*/
void SwapNum(int* p, int l, int r) {
int t;
t = *(p + l);
*(p + l) = *(p + r);
*(p + r) = t;
}
/*
* 函数名称:Initial
* 函数参数:数组元素个数num
* 函数目的:初始化,并输入数组元素的值
*/
void Array::Initial(int num) {
int i;
n = num;
a = (int*)malloc(num);
for (i = 1; i <= n; i++) {
cin >> *(a + i);
}
}
/*
* 函数名称:PrintArray
* 函数目的:输出数组中的所有元素
*/
void Array::PrintArray() {
for (int i = 1; i <= n; i++) {
cout << *(a + i) << " ";
}
cout << endl;
}
/*
* 冒泡排序实现:
*/
void Array::BubbleSort() {
int i, j;
for (i = n; i > 1; i--) {
for (j = 1; j < i; j++) {
if (*(a + j) > *(a + j + 1)) {
SwapNum(a, j, j+1);
}
}
}
}
/*
* 插入排序实现:
*/
void Array::InsertSort() {
int i, j;
for (i = 2; i <= n; i++) {
int turn = i;
for (j = i - 1; j >= 1; j--) {
if (*(a + j) > *(a + turn)) {
SwapNum(a, j, turn);
turn = j;
}
else break;
}
}
}
/*
* 选择排序实现:
*/
void Array::SelectSort() {
int i, j;
for (i = 1; i <= n; i++) {
int k = i;
for (j = i + 1; j <= n; j++) {
if (*(a + j) < *(a + k)) k = j;
}
if (k != i) SwapNum(a, i, k);
}
}
2016/10/8
简单排序算法 C++类实现的更多相关文章
- 简单排序算法设计(Java)
总共有八种排序算法,还是慢慢看吧 1.简单排序算法 简单排序算法就是设置标兵,逐个比较数,然后查找插入位置,插入 public static void p(int[] a){ for(int i=0; ...
- 用javascript实现简单排序算法
声明:本文为原创文章,如需转载,请注明来源WAxes,谢谢! 本文为楼主自己的学习记录文章,若有不当之处请斧正. 本文主要记录排序算法 [冒泡排序] 感觉这个是最简单的排序算法了.直接引用维基百科里的 ...
- python实现简单排序算法
算法 递归两个特点: 调用自身 有穷调用 计算规模越来越小,直至最后结束 用装饰器修饰一个递归函数时会出现问题,这个问题产生的原因是递归的函数也不停的使用装饰器.解决方法是,只让装饰器调用一次即可,那 ...
- js的几种简单排序算法及其效率实测
function swap(arr,index1,index2){ var t = arr[index1]; arr[index1] = arr[index2]; arr[index2] = t; } ...
- 三种简单排序算法(java实现)
一.冒泡排序 算法思想:遍历待排序的数组,每次遍历比较相邻的两个元素,如果他们的排列顺序错误就交换他们的位置,经过一趟排序后,最大的元素会浮置数组的末端.重复操 作 ...
- 几个简单排序算法的Python实现
一,冒泡排序 冒泡排序我就不多讲了,大体上就是比较相邻的两个数,每次把较大的数沉底.流程图大致上如下: 图是截得别人的,只是说明一下,代码没有参看别人的,写的不好,有更好的写法可以一起探讨.下面是代码 ...
- JS三种简单排序算法
冒泡排序:最简单.最慢.长度小于7的时候最优 插入排序:比冒泡要快比快速排序和希尔排序慢,数据量小的时候优势大 快速排序:速度很快 //js利用systemSort进行排序 systemSort: ...
- 用js实现简单排序算法
一.冒泡排序 var arr1=[3,9,2,7,0,8,4]; for(var i=0;i<arr1.length;i++){ for(var j=i+1;j<arr1.length;j ...
- Java实现三大简单排序算法
一.选择排序 public static void main(String[] args) { int[] nums = {1,2,8,4,6,7,3,6,4,9}; for (int i=0; i& ...
随机推荐
- 前端代理nproxy
一.场景/用途 前端代理的用途,相信大家都清楚.应用场景很多,如—— . 将线上的静态资源文件(JS.CSS.图片)替换为本地相应的文件,来调试线上(代码都被压缩过)的问题: . 本地开发过程,当后端 ...
- 禅道bug安装报错
[root@lnmp src]# grep "session.save" /etc/php.ini ; http://php.net/session.save-handler se ...
- iptables 开启80端口
[root@v01-svn-test-server online]# iptables -F#清空规则 [root@v01-svn-test-server online]# iptables -L# ...
- 如何将win7安装到 移动硬盘/U盘 及 VHD、BCD等相关知识 链接汇总
如何将win7安装到 移动硬盘/U盘? 从u盘启动win7/2008 R2的方法,更新:换机器免sysprep的方法:http://www.360doc.com/content/11/1103/14/ ...
- 在Linux中创建静态库.a和动态库.so
转自:http://www.cnblogs.com/laojie4321/archive/2012/03/28/2421056.html 在Linux中创建静态库.a和动态库.so 我们通常把一些公用 ...
- C#环境datagidview添加删除操作
添加 行 dataGridView1.Rows.Add();//添加空行 dataGridView1.Rows.Add("a","b"……);//添加指定列数的 ...
- hihoCoder 1160 攻城略地
原图可能有多个连通分量,先DFS找出每个连通分量中最小节点,这些必然是要攻占的城市. 设 n 为节点数, m 为边数, cnt 为初始连通分量数,在剩下的边数不小于 m - (n - cnt) 的时候 ...
- kmp 和boyer-moore
<html> <head> <meta http-equiv="content-type" content="text/html; char ...
- storm源码之理解Storm中Worker、Executor、Task关系 + 并发度详解
本文导读: 1 Worker.Executor.task详解 2 配置拓扑的并发度 3 拓扑示例 4 动态配置拓扑并发度 Worker.Executor.Task详解: Storm在集群上运行一个To ...
- 洛谷 P1009 阶乘之和 Label:高精度
题目描述 用高精度计算出S=1!+2!+3!+…+n!(n≤50) 其中“!”表示阶乘,例如:5!=5*4*3*2*1. 输入输出格式 输入格式: 一个正整数N. 输出格式: 一个正整数S,表示计算结 ...