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

2024-06-22力扣每日一题

链接:

2663. 字典序最小的美丽字符串

题意

要求字符串内不存在任何长度为 2 或更长的回文子字符串,则在任意位置不存在aaaba形式

由于要被给定字符串字典序大,且找到符合条件的字典序最小字符串,则竟可能对靠后的字符做加法和进位

莽一波一直处理最后一个字符,寄的理所当然哈哈

因为默认给的是符合无回文的字符串,所以没被更改过的字符都不考虑,从最靠前的被修改过的字符开始判断它和前面是否构成回文,如果回文则字符加一,如不回文则处理靠后的字符。

代码很丑陋,看看注释得了

实际代码:

#include<bits/stdc++.h>
using namespace std;
string smallestBeautifulString(string s, int k)
{int lg=s.length(),mao=lg-1,zt=1;while(true){if(zt)//第一次无条件执行 {s[mao]++;}if(mao>1){if(s[mao]==s[mao-1] || s[mao]==s[mao-2]){while(s[mao]==s[mao-1] || s[mao]==s[mao-2]) s[mao]++;//有回文则++}else if(!zt) mao++;//无回文则处理后面的字符}else if(mao>0){if(s[mao]==s[mao-1]){while(s[mao]==s[mao-1]) s[mao]++;}else if(!zt) mao++;}else if(!zt) mao++;if(zt) zt=0;//cout<<"mao:"<<mao<<endl; if(mao>=lg) break;//cout<<"s[mao]:"<<s[mao]<<endl; while(s[mao]-'a'+1>k)//进位则需要处理新的字符{s[mao]-=k;mao--;if(mao<0) return "";//首字符还进位则无符合条件字符串else s[mao]++;}}return s;
}
int main()
{string s;int k;cin>>s>>k;string ans=smallestBeautifulString(s,k);cout<<ans<<endl;return 0;
}

限制:

  • 1 <= n == s.length <= 105
  • 4 <= k <= 26
  • s 是一个美丽字符串
http://www.lryc.cn/news/383473.html

相关文章:

  • S_LOVE多端恋爱小站小程序源码 uniapp多端
  • 如何避免MySQL的死锁或性能下降
  • 《C语言》编译和链接
  • group by和select的兼容性问题
  • 切面aspect处理fegin调用转本地调用
  • Linux 磁盘挂载与分区
  • Open3D 将ShapeNet数据集txt转pcd
  • 综合项目实战--jenkins节点模式
  • WhaleStudio 2.6重磅发布!调度模块WhaleScheduler更新78项核心功能
  • 笔记101:OSQP求解器的底层算法 -- ADMM算法
  • Java银系统/超市收银系统/智慧新零售/ERP进销存管理/线上商城/h5/小程序
  • 大学网页制作作品1
  • 【会议征稿,IEEE出版】第三届机器人、人工智能与智能控制国际会议(RAIIC 2024,7月5-7)
  • 离线部署OpenIM
  • sql:between and日期毫秒精度过多导致的查询bug
  • 【日常记录】【JS】优雅检测用户是否在指定元素的外部点击
  • MySQL 5.7.42 主从复制环境搭建
  • 【Excel】单元格如何设置可选项、固定表头
  • 大模型ReAct:思考与工具协同完成复杂任务推理
  • 深入了解银行核心账务系统及其测试的重要性
  • 实习公司内部OA系统项目经验
  • Ansys Zemax|在设计抬头显示器(HUD)时需要使用哪些工具?
  • Linux系统移动光标类命令
  • Vitis Accelerated Libraries 学习笔记--Vision 库的组织结构
  • HTML+CSS 彩色浮雕按钮
  • ChatBI开源实现: 基于SuperSonic的AI+BI的产品设计
  • 【嵌入式Linux】i.MX6ULL 外部中断服务函数的初始化
  • 线性代数、矩阵计算
  • PostgreSQL 高级功能(五)
  • 食品企业仓储式批发零售一体化解决方案