数位排序

小蓝对一个数的数位之和很感兴趣,今天他要按照数位之和给数排序。

当两个数各个数位之和不同时,将数位和较小的排在前面,当数位之和相等时,将数值小的排在前面。

例如,\(2022\) 排在 \(409\) 前面,因为 \(2022\) 的数位之和是 \(6\),小于 \(409\) 的数位之和 \(13\)。

又如,\(6\) 排在 \(2022\) 前面,因为它们的数位之和相同,而 \(6\) 小于 \(2022\)。

给定正整数 \(n,m,\)请问对 $1 $到 \(n\) 采用这种方法排序时,排在第 \(m\) 个的元素是多少?

输入格式

输入第一行包含一个正整数 \(n\)。

第二行包含一个正整数 \(m\)。

输出格式

输出一行包含一个整数,表示答案。

数据范围

对于 \(30%\) 的评测用例,\(1≤m≤n≤300\)。

对于 \(50%\) 的评测用例,\(1≤m≤n≤1000\)。

对于所有评测用例,\(1≤m≤n≤106\)。

输入样例:

13

5

输出样例:

3

样例解释

\(1\) 到 \(13\) 的排序为:\(1,10,2,11,3,12,4,13,5,6,7,8,9\)。

第 \(5\) 个数为 \(3\)。

TLE(通过了 5/10个数据)

快排+过程处理

点击查看代码
#include<iostream>
#include<algorithm>
using namespace std; int n,m;
const int N = 1e6 + 10;
int a[N]; int get(int x){
int ret = 0;
while(x){
ret += x % 10;
x /= 10;
}
return ret;
} bool cmp(int a,int b){
if(get(a) != get(b))return get(a) < get(b);
else return a < b;
}
int main(){
cin >> n >> m;
for(int i = 1; i <= n; i ++)a[i] = i;
sort(a + 1,a + n + 1,cmp);
cout << a[m];
//for(int i = 1; i <= n; i ++)cout << a[i] << " ";
}

TLE(通过了 7/10个数据)

冒泡加过程处理

点击查看代码
#include<iostream>
#include<algorithm>
using namespace std; int n,m;
const int N = 1e6 + 10;
int a[N]; int get(int x){
int ret = 0;
while(x){
ret += x % 10;
x /= 10;
}
return ret;
} bool cmp1(int a,int b){
if(get(a) != get(b))return get(a) > get(b);
else return a > b;
} bool cmp2(int a,int b){
if(get(a) != get(b))return get(a) < get(b);
else return a < b;
}
int main(){
cin >> n >> m;
for(int i = 1; i <= n; i ++)a[i] = i;
if(m > n - m){
for(int i = 1; i <= n - m + 1; i ++){
for(int j = 1; j < n - i + 1; j ++){
if(cmp1(a[j],a[j + 1]))swap(a[j],a[j + 1]);
}
}
cout << a[m];
}
else{
for(int i = 1; i <= m; i ++){
for(int j = 1; j < n - i + 1; j ++){
if(cmp2(a[j],a[j + 1]))swap(a[j],a[j + 1]);
}
}
cout << a[n - m + 1];
}
//or(int i = 1; i <= n; i ++)cout << a[i] << " ";
//cout << endl << a[m] << " " << a[n - m + 1];
}

Code(AC)\(O(nlogn)\)

快排+预处理 \(3489 ms\)

点击查看代码
#include<iostream>
#include<algorithm>
#include<vector>
#define X first
#define Y second using namespace std; typedef pair<int,int> PII;
int n,m;
const int N = 1e6 + 10;
vector<PII> q; int get(int x){
int ret = 0;
while(x){
ret += x % 10;
x /= 10;
}
return ret;
} bool cmp(PII a,PII b){
if(a.Y != b.Y)return a.Y < b.Y;
else return a.X < b.X;
} int main(){
cin >> n >> m;
for(int i = 1; i <= n; i ++)q.push_back({i,get(i)});
sort(q.begin(),q.end(),cmp);
cout << q[m - 1].first;
}

Code(AC) \(O(n)\)

快速选择\(287 ms\)

点击查看代码
#include <iostream>
#include <algorithm>
using namespace std; const int N = 1000010; int n, m;
int w[N], s[N]; bool cmp(int a, int b)
{
if (s[a] != s[b]) return s[a] < s[b];
return a < b;
} int quick_select(int l, int r, int k)
{
if (l == r) return w[l];
int x = w[l + r >> 1], i = l - 1, j = r + 1;
while (i < j)
{
do i ++ ; while (cmp(w[i], x));
do j -- ; while (cmp(x, w[j]));
if (i < j) swap(w[i], w[j]);
}
if (k <= j) return quick_select(l, j, k);
return quick_select(j + 1, r, k);
} int main()
{
scanf("%d%d", &n, &m);
for (int i = 1; i <= n; i ++ )
{
w[i] = i;
for (int j = i; j; j /= 10)
s[i] += j % 10;
}
printf("%d\n", quick_select(1, n, m));
return 0;
}

注意

  1. vector从0开始而不是1
  2. nlogn时间复杂度 -> 先对每个数进行预处理,保存数位和再进行排序,而不是排序过程中进行处理

数位排序【第十三届蓝桥杯省赛C++C组】的更多相关文章

  1. 纸张尺寸【第十三届蓝桥杯省赛C++C组】

    纸张尺寸 在 ISO 国际标准中定义了 \(A0\) 纸张的大小为 \(1189mm×841mm\),将 \(A0\) 纸沿长边对折后为 \(A1\) 纸,大小为 \(841mm×594mm\) ,在 ...

  2. 第十三届蓝桥杯省赛C/C++ B组

    @(第十三届蓝桥杯省赛C/C++B组) A顺子日期 答案是1478 B顺子日期 答案14(如果012算的话) C刷题统计 数据范围1e18,所以不能直接暴力,先取余,再暴力剩下的 #include&l ...

  3. 求和【第十三届蓝桥杯省赛C++A/C组 , 第十三届蓝桥杯省赛JAVAA组】

    求和 给定 \(n\) 个整数 \(a1,a2,⋅⋅⋅,an\),求它们两两相乘再相加的和,即 \(S=a1⋅a2+a1⋅a3+⋅⋅⋅+a1⋅an+a2⋅a3+⋅⋅⋅+an−2⋅an−1+an−2⋅a ...

  4. 四平方和【第七届蓝桥杯省赛C++A/B组,第七届蓝桥杯省赛JAVAB/C组】

    四平方和 四平方和定理,又称为拉格朗日定理: 每个正整数都可以表示为至多 4 个正整数的平方和. 如果把 0 包括进去,就正好可以表示为 4 个数的平方和. 比如: \(5=0^2+0^2+1^2+2 ...

  5. 第九届蓝桥杯国赛+第二天的第11届acm省赛的总结

    第九届蓝桥杯国赛+第二天的第11届acm省赛的总结 25号坐的去北京的火车,10个小时的火车,然后挤了快两个小时的地铁,最终达到了中国矿业大学旁边的订的房间.12个小时很难受,晕车症状有点严重,吃了快 ...

  6. 2021蓝桥杯省赛C++A组试题E 回路计数 状态压缩DP详细版

    2021蓝桥杯省赛C++A组试题E 回路计数 状态压缩DP 题目描述 蓝桥学院由21栋教学楼组成,教学楼编号1到21.对于两栋教学楼a和b,当a和b互质时,a和b之间有一条走廊直接相连,两个方向皆可通 ...

  7. 第十届蓝桥杯省赛JavaB组个人题解

    前言 以下的第十届蓝桥杯Java B组省赛的题目题解只是我个人的题解,提供一些解题思路,仅作参考,如有错误,望大家指出,不甚感激,我会及时更改. 试题 A: 组队 ----- 答案:490 [问题描述 ...

  8. 2016第七届蓝桥杯C/C++语言A组

    一:问题: 某君新认识一网友.当问及年龄时,他的网友说:“我的年龄是个2位数,我比儿子大27岁,如果把我的年龄的两位数字交换位置,刚好就是我儿子的年龄” 请你计算:网友的年龄一共有多少种可能情况? 提 ...

  9. 2019年第十届蓝桥杯省赛总结(JavaA组)

    //update3.28:省一rank4,莫名进了国赛好神奇.. 记yzm10第一次体验A组(纯粹瞎水). 早闻山东的JavaA组神仙打架,进国赛都成了奢望(往年只有五个名额),因此抱着做分母的心态来 ...

随机推荐

  1. 聊一聊被 .NET程序员 遗忘的 COM 组件

    一:背景 1.讲故事 最近遇到了好几起和 COM 相关的Dump,由于对 COM 整体运作不是很了解,所以分析此类dump还是比较头疼的,比如下面这个经典的 COM 调用栈. 0:044> ~~ ...

  2. 【算法】基础DP

    参考资料 背包九讲 一.线性DP 如果现在在状态 i 下,它上一步可能的状态是什么. 上一步不同的状态依赖于什么. 根据上面的分析,分析出状态和转移方程.注意:dp 不一定只有两维或者一维,一开始设计 ...

  3. 基于tauri+vue3.x多开窗口|Tauri创建多窗体实践

    最近一种在捣鼓 Tauri 集成 Vue3 技术开发桌面端应用实践,tauri 实现创建多窗口,窗口之间通讯功能. 开始正文之前,先来了解下 tauri 结合 vue3.js 快速创建项目. taur ...

  4. 14.-F对象和Q对象

    一.F对象 一个F对象代表数据库中某条记录的字段的信息 作用 通常是对数据库中的字段值在不获取的情况下进行操作 用于属性(字段)之间的比较   语法: from django.db.models im ...

  5. golang中的错误处理

    0.1.索引 https://waterflow.link/articles/1666716727236 1.panic 当我们执行panic的时候会结束下面的流程: package main imp ...

  6. 加速乐逆向 cookies 参数

    简介 加速乐用于解决网站访问速度过慢及网站反黑客问题. 爬取使用该技术网站时需要携带特定的cookies参数(有的是__jsl_clearance_s,有的__jsl_clearance),本项目以一 ...

  7. 2022NISACTF--WEB

    easyssrf 打开题目,显示的是 尝试输入, 发现输入flag有东西 读取文件 访问下一个网站 读取文件 不能以file开头 直接伪协议,base64解码 checkIn 奇怪的unicode编码 ...

  8. 浅谈MYSQL的索引以及它的数据结构

    什么是索引 mysql的数据是持久化到磁盘的,写SQL查询数据也就是在磁盘的某个位置查找符合条件的数据,但是磁盘IO比起内存效率是极慢的,特别是数据量大的时候,这时候就需要引入索引来提高查询效率: 在 ...

  9. shell文件报错syntax error near unexpected token '$'\r''

    本来跑的好好得一个文件,在windows下修改了,然后移植到linux就报错了. 找了一圈以下是解决方案: 这种情况发生的原因是因为你所处理的文件换行符是dos格式的"\r\n" ...

  10. 基于python的数学建模---高阶样条插值

    为了满足对函数光滑性的需要,我们可以使用一种有弹性的长条(称之为样条),强迫它弯曲通过样本点. import numpy as npimport matplotlib.pylab as plfrom ...