问题遇到的现象和发生背景
我不知道为什么显示出来的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开始往上)
我的解答思路和尝试过的方法
我想要达到的结果
把数组按字典序排列(我只学到数组)