C语言算法打卡回文串验证算法题解
作者:乔乔家的龙龙 发布时间:2022-05-29 22:54:10
概念
所谓回文串,就是字符串反转以后和原串相同,如 abba 和 lippil。对于回文串还是比较容易去验证的,从字符数组的两端开始向中间靠拢去验证字符是否相等,但这里是否需要考虑字符数组长度的奇偶性呢?其实是不用的,下面一起来看看:
Leetcode例题:
1.回文串的验证
2.有效回文
3.回文排列
(1,2题是一样的,合并讲解吧)
点杀回文排列
先讲回文排列吧,简单一点。首先我们的思路要清楚,无非就是找出相同的字符并统计他出现的次数,我们保证每个字符只能出现偶数次,最多允许一个字符出现奇数个(奇数位字符串的中间元素)
代码如下:
char Func(char* s)
{
int i, count = 0;
int a[128] = { 0 };
int sz = strlen(s);//计算字符数组长度来作为循环判断部分
for (i = 0; i < sz; i++)
{
a[s[i]]++;//统计相同字符出现次数,有点像哈希表
}
for (i = 0; i < 128; i++)
{
if (a[i] % 2 == 1)//判断出现次数是否为偶数
count++;
if (count >= 2)//判断是否最多存在一个出现奇数次的元素
return false;
}
return true;
}
注意,这里面有一些重要细节:
1.数组 s 为 char 类型,字符数组在内存中存储方式是ASCII码值,s[ i ]就是在一一列举其中元素,假如我收到一个 ‘ a ’,a以ASCII码值作为下标++,第二个‘ a ’找到后依然是用相同的ASCII码值作为下标再++;这就是我统计数组中相同元素的次数的原理。
2. 数组初始化 a [128]不能更改是因为ASCII码值一共是128个,0~127。
3.强调最多一位为奇数次出现的字符的特殊情况。
点杀回文验证(有效性)
这道题就是典型的指针对撞题,因为题目告诉考虑数字和字符,我们写的时候就可以不考虑字符的大小写,这种方法需要灵活使用库函数。
需要先判断字符串中的字符是字母或数字,若不是,就pass掉。在 C 语言中可以用 isalnum() 函数去判断。
忽略字母的大小写,所以可以将待比较的字符转化为小写或大写,然后再比较。在 C 语言中可以用 tolower() 和 toupper() 函数。
对撞指针
一根指针指向头,满足条件时,往右移动;一根指针指向尾,满足条件时,往左移动;最后两根指针相遇,循环条件一般是前下标(指针)小于后下标(指针)。
送上代码:
char Fun(char * s)
{
int left = 0, right = strlen(s) - 1;
while (left < right)
{ //筛选出数字与字符
if (!isalnum(s[left])) {
left++;
} else if (!isalnum(s[right])) {
right--;
} else { //合并为小写(大写)来判断
if (tolower(s[left]) != tolower(s[right])) {
return false;
}
left++;
right--;
}
}
return true;
}
今天就到这里了家人们,先摸了。
来源:https://blog.csdn.net/qq_61500888/article/details/121345406


猜你喜欢
- 本文实例为大家分享了Java使用poi操作excel的具体代码,供大家参考,具体内容如下依赖poi的jar包,pom.xml配置如下:<
- 克隆,想必大家都有耳闻,世界上第一只克隆羊多莉就是利用细胞核移植技术将哺乳动物的成年体细胞培育出新个体,甚为神奇。其实在Java中也存在克隆
- 查看apiDemos,找到View/Animation/shake找到对应的动画代码,直接拷贝过来当导入一个项目的时候,报R文件不存在,很多
- Spring容器可以自动装配相互协作bean之间的关系,这有助于减少对XML配置,而无需编写一个大的基于Spring应用程序的较多的<
- 什么是BottomNavigationView底部菜单栏BottomNavigationView的简单用法需求:如上图所示。点击测试一菜单,
- 我们有很多 Coding Style 或 代码规范。 但这一条可能会经常被我们所遗忘,就是我们 经常会在函数的参数里使用bool参数,这会大
- 那么什么是性能测试,它与功能测试有什么样的区别?性能测试是通过自动化的测试工具模拟多种正常、峰值以及异常负载条件来对系统的各项性能指标进行测
- RabbitMQ的一些基本组件Producer:消息的生产者Consumer:消息的消费者Broker:MQ服务器,管理队列、消息Messa
- 效果图:布局文件里包括了一个ImageView和两个Button控件,而在MainActivity了初始化控件。<?xml versi
- 本文实例为大家分享了java WebSocket实现聊天消息推送功能的具体代码,供大家参考,具体内容如下环境:JDK.1.7.0_51apa
- 一、文件上传概述实现Web开发中的文件上传功能,需要两步操作:1、在Web页面中添加上传输入项 <form
- 介绍写给刚刚入坑 Java 的各位,无论你是计算机领域从业者,亦或是科班出身的专业人才。当然也包括我在内,Hello World 相信大家都
- 概述中国特色社会主义乱码问题是我们经常会碰到的问题,解决的办法有很多,本文分别介绍了GET方式和POST方式中文乱码解决方案中一劳永逸的办法
- 首先,来看一下,快速排序的实现的动态图:快速排序介绍:快速排序,根据教科书说法来看,是冒泡排序的一种改进。快速排序,由一个待排序的数组(ar
- 首先我们设计了模块层次图,当然图中只是给出一种实现方式,不局限于此。具体见下图。主要功能介绍如下:1)请求接口层。处理HTTP请求,及响应2
- 一、前言程序中经常会用到TabControl控件,默认的控件样式很普通。而且样式或功能不一定符合我们的要求。比如:我们需要TabContro
- 本实例是为了实现在管理后台实现微信菜单的添加删除管理。1、首先我们需要新建一个数据库表用于存放menu菜单项可包含的字段有id、父类id、n
- 一、目的本篇文章的目的是记录本人使用flutter加载与调用第三方aar包。二、背景本人go后端,业余时间喜欢玩玩flutter。一直有一个
- 1. 什么是AOPAOP (Aspect Oriented Programming)意为:面向切面编程,通过预编译方式和运行期 * 实现在
- 简介TreeMap使用红黑树存储元素,可以保证元素按key值的大小进行遍历。继承体系TreeMap实现了Map、SortedMap、Navi