我不知道为什么显示出来的20会在11前面
#include<iostream>
using namespace std;
int num(int n)
{
int sum = 0;
for (; n != 0;)
{
sum++;
n=n/10;
}
return sum;
}
int ten(int n)
{
int mul = 1;
for (int i = 1; i <= n; i++)
{
mul *= 10;
}
return mul;
}
bool compare(int m, int n)
{
int q = num(m), p = num(n);
for (; q>0 && p > 0; q--, p--)
{
if (((m % ten(q)) / ten(q - 1)) > ((n % ten(p)) / ten(p - 1)))
{
return true;
break;
}
}
return false;
}
int main()
{
int n, k;
while (cin >> n >> k)
{
int* p = new int[n];
for (int i = 0, j = 1; i < n; i++, j++)
{
p[i] = j;
}
for (int z = 0; z < n; z++)
{
for (int z1 = z + 1; z1 < n; z1++)
{
if (compare(p[z], p[z1]))
{
int temp = p[z];
p[z] = p[z1];
p[z1] = temp;
}
}
}
cout << p[k - 1] << endl;
}
}
我感觉在compare这个函数里11和20对比应该返回的是false,也就是说11会在20的前面,但是不清楚为什么最后显示的20会在11的前面(当输入的n为22,k从1开始往上)
把数组按字典序排列(我只学到数组)
字典序是什么意思?到底按数值排序,还是按字符串排序?123和99到底哪个大?
看看是不是 20 实际上 写成了 02
可以 比较的时候 输出 看看 到底是哪两个值在比较