现在对每个数的各个位数加起来的和从小到大排列
然后再把排列后的顺序按原数组值输出
比如a[]={46,22,15}
输出的是:22 15 46
我想了一个方法,但感觉效率不好,有没有更简洁的方法呢
大家一起讨论下吧
用STL的 map做快些 按照关键字(各位数加起来后的和)进行排序
#include<map>
#include<iostream>using namespace std;
class Compare {//用来对关键字进行排序
public:bool operator()( int key1, int key2 ) const {
return key1<=key2?1:0;
}
};int sum(int n)//计算各位之和
{
int sum=0;
while(n)
{
sum+=n%10;
n/=10;
}
return sum;
}int main()
{
int a[6]={123,45,67,2222,96,9};//给定的数组
copy(a,a+6,ostream_iterator<int>(cout,\" \")); //输出最初的数组
map<int,int,Compare> s;
for(int i=0;i<6;++i) s[sum(a[i])]=a[i]; //按照关键字排序赋值
cout<<\"\nAfter Sorted:\n\";
for( map<int,int,Compare>::iterator iter = s.begin(); iter != s.end(); iter++ ) cout <<(*iter).second<<\" \";//输出\"排序\"后的数组
cout<<endl;return 0;
}
[此贴子已经被作者于2007-4-17 15:16:43编辑过]
上课回来了,这是我的方法。两个函数:
[CODE]int convert(int ival){
return ival % 10 + ival / 10;
}
void sort(int A[],int size){
for (int i = 1;i < size;++i){
if (convert(A[i]) < convert(A[i-1])){
int temp = A[i],j = i;
do{
A[j] = A[j-1];
--j;
}
while (j > 0 && convert(temp) < convert(A[j-1]));
A[j] = temp;
}
}
}
///////////////////////////////////////////////
///////////////////下面是测试//////////////////
int main(){
const int size = 8;
int list[size] = {12,99,81,46,33,10,66,77};
sort(list,size);
for (int i = 0;i < size;++i)
cout << list[i] << " ";
cout << endl;
return 0;
}[/CODE]