7-6 数字排序 (10 分)
给出一个十进制正整数 n,按从大到小的顺序输出其中包含的数字。重复出现的数字,仅输出一次。
输入格式:
输入在一行中给出一个正整数 n,且保证其大小不超出整型的表示范围。
输出格式:
在一行中按从大到小的顺序输出 n 中包含的数字。重复的数字,仅输出一次。
输入样例1:
100
输出样例1:
10
输入样例2:
271828
输出样例2:
8721
#include<iostream>
#include<algorithm>
int clear(int*, int);
int main(void)
{
std::ios::sync_with_stdio(false);
std::cin.tie(0);
int n, cnt = 0, tmp = 0;
std::cin >> n;
tmp = n;
while (tmp)
{
cnt++;
tmp /= 10;
}
int* p = new int[cnt];
for (int i = 0; i < cnt; i++)
{
p[i] = n % 10;
n /= 10;
}
int t = clear(p, cnt);
for (int i = 0; i < t - 1; i++)
for (int j = 0; j