服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - C语言算法打卡回文串验证算法题解

C语言算法打卡回文串验证算法题解

2022-09-24 16:43乔乔家的龙龙 C/C++

这篇文章主要为大家介绍了C语言算法打卡万人千提的leetcode回文串的验证算法题解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步

概念

所谓回文串,就是字符串反转以后和原串相同,如 abba 和 lippil。对于回文串还是比较容易去验证的,从字符数组的两端开始向中间靠拢去验证字符是否相等,但这里是否需要考虑字符数组长度的奇偶性呢?其实是不用的,下面一起来看看:

 

Leetcode例题:

 

1.回文串的验证

C语言算法打卡回文串验证算法题解

 

2.有效回文

C语言算法打卡回文串验证算法题解

 

3.回文排列

C语言算法打卡回文串验证算法题解

(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;
    }         

今天就到这里了家人们,先摸了。

以上就是C语言算法打卡回文串验证算法题解的详细内容,更多关于C语言回文串算法验证的资料请关注服务器之家其它相关文章!

原文链接:https://blog.csdn.net/qq_61500888/article/details/121345406

延伸 · 阅读

精彩推荐
  • C/C++C++类的大小介绍

    C++类的大小介绍

    这篇文章主要介绍了C++类的大小,在C++中,结构体和类的唯一区别就是结构体和类具有不同的默认访问控制属性,下面一起进入文章查看详细内容...

    学渣的C/C++3492022-02-22
  • C/C++C++实现单张图片读取和保存

    C++实现单张图片读取和保存

    这篇文章主要为大家详细介绍了C++语言读取和保存单张图片的代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    一棹烟波8432021-07-02
  • C/C++数据结构与算法 排序(冒泡,选择,插入)

    数据结构与算法 排序(冒泡,选择,插入)

    这篇文章主要介绍了数据结构与算法 排序(冒泡,选择,插入)的相关资料,这里对冒泡,选择和插入都做有实例,需要的朋友可以参考下...

    xiaohusaier4162021-05-25
  • C/C++C语言的堆串操作详解

    C语言的堆串操作详解

    大家好,本篇文章主要讲的是C语言的堆串操作详解,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下...

    犀牛超人10392022-09-21
  • C/C++C++实现位图排序实例

    C++实现位图排序实例

    这篇文章主要介绍了C++实现位图排序,是比较重要的排序算法,需要的朋友可以参考下...

    C++教程网10082021-01-27
  • C/C++自己简单封装的一个CDialog类实例

    自己简单封装的一个CDialog类实例

    这篇文章主要介绍了自己简单封装的一个CDialog类,实例分析了自定义封装CDialog类的相关技巧,比较简单易懂,需要的朋友可以参考下...

    司青6412021-02-24
  • C/C++C++实现LeetCode(52.N皇后问题之二)

    C++实现LeetCode(52.N皇后问题之二)

    这篇文章主要介绍了C++实现LeetCode(52.N皇后问题之二),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下...

    Grandyang3492021-11-29
  • C/C++如何用C语言生成简单格式的xml

    如何用C语言生成简单格式的xml

    本篇文章是对使用C语言生成简单格式的xml的实现代码进行了详细的分析介绍,需要的朋友参考下...

    C语言教程网2982020-12-10