题目传送门
题目描述 Description
有一组两位数,请你按照数字的十位数从大到小排序,如果十位数相同按照个位数从小到大排序
输入描述 Input Description
第一行为一个整数n
第二行有n个正整数,中间用空格分开
输出描述 Output Description
输出为一行排序好的数字,中间用空格分开
样例输入 Sample Input
3
23 21 10
样例输出 Sample Output
21 23 10
数据范围及提示 Data Size & Hint
1<=n<=100
10<=每个数字<=99
同学要的题解
这道题就是一个经典的取位数的数学题
我们在每次排序中写一个位数的大小判断就行了
代码如下:
#include<bits/stdc++.h>
using namespace std;
int n,a[105];
bool cmp(int a,int b){
if(a/10%10!=b/10%10) return a/10%10>b/10%10;
if(a%10!=b%10) return a%10<b%10;
}
int main(){
cin>>n;
for(int i=1;i<=n;i++) cin>>a[i];
sort(a+1,a+n+1,cmp);
for(int i=1;i<=n;i++) cout<<a[i]<<" ";
return 0;
}
yc:kimi_a