【leetcode 详解】生成特殊数字的最少操作【中等】(C++思路精析)

题目见下:

测试数据:

解题思路笔记:

最初拿到这道题是很蒙的,联想不到什么数据结构的模型(肯定是笔者积累太少了),甚至惯性地想怎么实现"删除数字"的操作:在原字符串中抽出一个字符然后将剩余数字按原顺序拼接?

看着看着下面的测试数据,我突然意识到,能整除25的数确实很特殊,即若长度足够,则必然以【00,50, 25, 75】来结尾,这样一来,未知长度的字符串问题,就转化为了:专注于找可以放在结尾的两字符的问题。

进一步观察题目要求可以发现,既然咱们要的就是 "最小删除个数" 这么个结果,中间过程怎么实现都行,也就是不必按题目表述的 "删除一个字符,检查是否可整除25" 介么生硬地来。这大概也是像笔者一样的编程初学者容易陷入的误区,实现过程的思路总是跟着题目叙述跑,但优质的(时空复杂度较低)的解法往往需要明确问题核心,创意性地从新的角度切入。

//更多创意性解法,这里推荐文章

PTA 7-4 列车调度(C/ C++ 一个数组就好啦!)-CSDN博客

最后,附上AC代码:

cpp 复制代码
class Solution {
private:
	void Myfunc(string num, int cur0, char c1, char c2, int &re)
	{
		int len = num.length();
		int help1=len, help2=len;
		while(1)
    	{
    		if(help1 >= cur0 ) help1 = num.rfind(c1, help1-1);
			if(help2 >= cur0 ) help2 = num.rfind(c2, help2-1);
			if(help1 < cur0 && help2 < cur0) break;
            //说明:调试过程中发现,num.npos其实就等于 -1,可以进行整数比较
		}
		if(help1 == num.npos && help2 == num.npos)
		{
			if(cur0 != num.npos && c1 == '0') re = len - 1;
            //只有当末尾数字为0时才进行这部操作
		} 
		else
		{
			if(help1 != num.npos) re = min(re, len-2-help1);
			if(help2 != num.npos) re = min(re, len-2-help2);
		} 
	}
	
public:
    int minimumOperations(string num) {
    	if(!num.compare("0")) return 0;//特殊情况处理
    	int re = num.length();
    	int cur0 = num.rfind('0'), cur5 = num.rfind('5');
    	if(cur0 != num.npos)
    	{
			Myfunc(num, cur0, '0', '5', re);
		}
    	if(cur5 != num.npos)
    	{
    		Myfunc(num, cur5, '2', '7', re);
		}
		return re;
    }
};

~希望对你有启发~

相关推荐
listhi5202 分钟前
FDA-MIMO雷达距离角度联合无模糊估计MATLAB仿真方案
开发语言·matlab
小白学大数据12 分钟前
使用随机时间间隔提升爬虫隐蔽性
开发语言·c++·爬虫·python
小小王app小程序开发13 分钟前
潮玩抽赏盲盒玩法开发全解析:算法、架构与合规风控
算法·架构
汉克老师17 分钟前
GESP2025年12月认证C++三级真题与解析(单选题1-8)
c++·算法·位运算·string·gesp三级·gesp3级·数据范围
week_泽21 分钟前
随机森林样本权重的计算-弱学习器
学习·算法·随机森林
Jasmine_llq24 分钟前
《P2151 [SDOI2009] HH 去散步》
算法·矩阵快速幂·快速幂算法 + 自定义矩阵乘法·图的邻接矩阵(边状态版)·状态拆分 + 转移条件·模运算(防溢出 + 结果取模)·二进制快速幂
The Last.H25 分钟前
Codeforces Round 1065 (Div. 3)A-C2
c++·算法
a程序小傲28 分钟前
米哈游Java面试被问:gRPC的HTTP/2流控制和消息分帧
java·开发语言·tcp/ip·http·面试·职场和发展·php
m0_7482486534 分钟前
C++高性能服务器框架----Http模块
服务器·c++·http
tudficdew39 分钟前
类型安全容器设计
开发语言·c++·算法