c语言数组冒泡法,数组排序 (冒泡法)

数组排序 (冒泡法)

/*

Name: 数组排序 (冒泡法)

Copyright:

Author:

Date: 14-10-07 15:04

Description:

*/

#include

#include

#include //size_t

using namespace std;

class order

{

public:

void actSmallToBig(int int_arr[],const size_t arr_sz)

{

pa=int_arr;

sz=arr_sz;

for(size_t ix=0; ix!=arr_sz; ++ix)

for(size_t _ix=ix; _ix!=arr_sz; ++_ix)

if(int_arr[ix]>=int_arr[_ix]) //交换过程

{

temp=int_arr[ix];

int_arr[ix]=int_arr[_ix];

int_arr[_ix]=temp;

}

}

void actBigToSmall(int int_arr[],const size_t arr_sz)

{

pa=int_arr;

sz=arr_sz;

for(size_t ix=0; ix!=arr_sz; ++ix)

for(size_t _ix=ix; _ix!=arr_sz; ++_ix)

if(int_arr[ix]<=int_arr[_ix]) //和actSmallToBig不同是“<=“

{

temp=int_arr[ix];

int_arr[ix]=int_arr[_ix];

int_arr[_ix]=temp;

}

}

void show()

{

for(int *pbegin=pa,*pend=pa+sz; pbegin!=pend; ++pbegin)

{

cout<

cout.flush();

}

}

order():temp(0) {}

private:

int *pa;

int temp;

size_t sz;

};

int main()

{

const size_t arrSize=10;

int arr[arrSize];

for(int *pbegin=arr,*pend=arr+arrSize; pbegin!=pend; ++pbegin)

{

int val;

cin>>val;

*pbegin=val;

}

order px;

px.actSmallToBig(arr,arrSize);

cout<

px.show();

cout<

px.actBigToSmall(arr,arrSize);

cout<

px.show();

cout<

system("pause");

return 0;

}

今天看到有人问怎么实现对任意多个数进行排序,这个只要把数组改成vector向量就行了.算法是一样的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值