当前位置: 首页 > news >正文

小于n的最大数 - 贪心算法 - C++

字节经典面试题
给定一个整数n,并从1~9中给定若干个可以使用的数字,根据上述两个条件,得到每一位都为给定可使用数字的、最大的小于整数n的数,例如,给定可以使用的数字为 {2,3,8} 三个数:给定 n=3589,输出3388;给定 n=8234,输出8233;……

#include <iostream>
#include <ostream>
#include <vector>
#include <algorithm>
using namespace std;
//找到小于x的最大值
int find_x(const vector<int>& digits, int x) {for (auto it = digits.rbegin(); it < digits.rend(); it++) {if (*it < x) {   return *it;}}return 0;
}
int process(vector<int>& digits, int n){sort(digits.begin(), digits.end());vector<int> aim;while(n>0){aim.push_back(n%10);n/=10;//cout<<n<<endl;}vector<int>ans(aim.size(), 0);for(int i=aim.size()-1; i>=0; i--){int now = find_x(digits, aim[i]);//当前的第i位找不到不合适,回溯降级需要降级if(now==0 && i==0){while(i<aim.size() && now==0){now = find_x(digits, aim[i]);i++;}//找到最高位还没有找到合适的,就要降级了if(i==aim.size()){ans = vector<int>(aim.size()-1, *(digits.end()-1));break;}else{//找到合适的了ans[i] = now;for(int k=0;k<i;k++){//后面的位都补充最大的数ans[k]=*digits.end();}break;}}else if(now ==0 ){now = digits[0];}ans[i]=now;}int ret=0;for(int m=ans.size()-1; m>=0; m--){ret*=10;ret+=ans[m];}return ret;
}int main()
{vector<int> m_digits= { 2,8,3 };cout <<process(m_digits, 2222) <<endl;return 0;
}
http://www.lryc.cn/news/516322.html

相关文章:

  • 【顶刊TPAMI 2025】多头编码(MHE)之极限分类 Part 3:算法实现
  • 解决CentOS 8 YUM源更新后报错问题:无法下载AppStream仓库元数据
  • [python3]Excel解析库-openpyxl
  • Docker 远程访问完整配置教程以及核心参数理解
  • 王老吉药业SRM系统上线 携手隆道共启战略合作新篇章
  • MyBatis 配置文件全解析
  • unity学习6:unity的3D项目的基本界面和菜单
  • 企业二要素如何用C#实现
  • 中科院空天院无人机视觉语言导航新基准!AeroVerse:模拟、预训练、微调和评估空中无人机具身世界模型的测试基准
  • Python安装(新手详细版)
  • Oracle DG备库数据文件损坏修复方法(ORA-01578/ORA-01110)
  • 安装Linux
  • 【文献精读笔记】Explainability for Large Language Models: A Survey (大语言模型的可解释性综述)(四)
  • 【OpenCV】使用Python和OpenCV实现火焰检测
  • SpringCloud(二)--SpringCloud服务注册与发现
  • 国内Ubuntu环境Docker部署CosyVoice
  • 嵌入式linux系统中QT信号与槽实现
  • 科研绘图系列:R语言单细胞数据常见的可视化图形
  • 使用 C++ 和函数式编程构建高效的 AI 模型
  • guestfish/libguestfs镜像管理工具简介
  • 如何在centos中进行有效的网络管理
  • Oracle清空表后如何恢复数据
  • ElasticSearch基础-文章目录
  • SpringMVC(二)原理
  • Selenium 自动化,如何下载正确的 ChromeDriver
  • [Linux]redis5.0.x升级至7.x完整操作流程
  • Java字符编码与正则表达式深度解析
  • 【C++】B2099 矩阵交换行
  • 论文解读 | NeurIPS'24 IRCAN:通过识别和重新加权上下文感知神经元来减轻大语言模型生成中的知识冲突...
  • edeg插件/扩展推荐:助力生活工作