B345148364 2021-11-29 15:18 采纳率: 100%
浏览 92
已结题

C++:假设整数序列1、2、3到n按字典序排序,现在给定非负整数n,在序列中找到第k个整数并输出其值。

问题遇到的现象和发生背景

我不知道为什么显示出来的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开始往上)

我的解答思路和尝试过的方法
我想要达到的结果

把数组按字典序排列(我只学到数组)

  • 写回答

2条回答 默认 最新

  • CSDN专家-link 2021-11-29 15:25
    关注

    字典序是什么意思?到底按数值排序,还是按字符串排序?123和99到底哪个大?

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 12月7日
  • 已采纳回答 11月29日
  • 创建了问题 11月29日

悬赏问题

  • ¥15 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值