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

C语言 | Leetcode C语言题解之第564题寻找最近的回文数

题目:

题解:

#define MAX_STR_LEN 32
typedef unsigned long long ULL;void reverseStr(char * str) {int n = strlen(str);for (int l = 0, r = n-1; l < r; l++, r--) {char c = str[l];str[l] = str[r];str[r] = c;}
}ULL * getCandidates(const char * n, int * returnSize) {int len = strlen(n);int pos = 0;ULL * candidates = (ULL *)malloc(sizeof(ULL) * 5);candidates[pos++] = (ULL)pow(10, len) + 1;candidates[pos++] = (ULL)pow(10, len - 1) - 1;char str[MAX_STR_LEN], prefix[MAX_STR_LEN];char candidate[MAX_STR_LEN];snprintf(str, (len + 1) / 2 + 1, "%s", n);ULL selfPrefix = atol(str);    for (ULL i = selfPrefix - 1; i <= selfPrefix + 1; i++) {sprintf(prefix, "%ld", i);sprintf(candidate, "%s", prefix);reverseStr(prefix);sprintf(candidate + strlen(candidate), "%s", prefix + (len & 1));candidates[pos++] = atoll(candidate);}*returnSize = pos;return candidates;
}char * nearestPalindromic(char * n){ULL selfNumber = atoll(n), ans = -1;int candidatesSize = 0;const ULL * candidates = getCandidates(n, &candidatesSize);for (int i = 0; i < candidatesSize; i++) {if (candidates[i] != selfNumber) {if (ans == -1 ||labs(candidates[i] - selfNumber) < labs(ans - selfNumber) ||labs(candidates[i] - selfNumber) == labs(ans - selfNumber) && candidates[i] < ans) {ans = candidates[i];}}}char * str = (char *)malloc(sizeof(char) * MAX_STR_LEN);sprintf(str, "%ld", ans);free(candidates);return str;
}
http://www.lryc.cn/news/488534.html

相关文章:

  • wsl虚拟机中的dockers容器访问不了物理主机
  • Spark RDD 的宽依赖和窄依赖
  • 二进制转十进制
  • 深度学习:神经网络中的非线性激活的使用
  • Python缓存:两个简单的方法
  • 原生微信小程序在顶部胶囊左侧水平设置自定义导航兼容各种手机模型
  • 经验笔记:远端仓库和本地仓库之间的连接(以Gitee为例)
  • 利用RAGflow和LM Studio建立食品法规问答系统
  • ffplay音频SDL播放处理
  • 自动化仪表故障排除法
  • WPF 中 MultiConverter ——XAML中复杂传参方式
  • 实验室管理现代化:Spring Boot技术方案
  • aws凭证(一)凭证存储
  • jmeter常用配置元件介绍总结之断言
  • JMeter监听器与压测监控之Grafana
  • MySQL8 安装教程
  • 聚焦 NLP 和生成式 AI 的创新与未来 基础前置知识点
  • 23种设计模式-访问者(Visitor)设计模式
  • ssm150旅游网站的设计与实现+jsp(论文+源码)_kaic
  • 【SKFramework框架】一、框架介绍
  • Arcgis地图实战三:自定义导航功能的实现
  • LLaMA-Factory 上手即用教程
  • 黑马点评 秒杀下单出现的问题:服务器异常---java.lang.NullPointerException: null(已解决)
  • 购物街项目TabBar的封装
  • C++游戏开发面试题及参考答案
  • 字符串的基本操作(C语言版)
  • C缺陷与陷阱 — 7 可移植性缺陷
  • 应急响应:玄机_Linux后门应急
  • C++:捕获 shared_from_this()和捕获this的区别
  • 网络协议之TCP