欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語(yǔ)言算法打卡回文串驗(yàn)證算法題解

 更新時(shí)間:2022年02月16日 10:55:43   作者:?jiǎn)虇碳业凝堼? 
這篇文章主要為大家介紹了C語(yǔ)言算法打卡萬(wàn)人千提的leetcode回文串的驗(yàn)證算法題解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步

概念

所謂回文串,就是字符串反轉(zhuǎn)以后和原串相同,如 abba 和 lippil。對(duì)于回文串還是比較容易去驗(yàn)證的,從字符數(shù)組的兩端開始向中間靠攏去驗(yàn)證字符是否相等,但這里是否需要考慮字符數(shù)組長(zhǎng)度的奇偶性呢?其實(shí)是不用的,下面一起來(lái)看看:

Leetcode例題:

1.回文串的驗(yàn)證

2.有效回文

3.回文排列

(1,2題是一樣的,合并講解吧)

點(diǎn)殺回文排列

先講回文排列吧,簡(jiǎn)單一點(diǎn)。首先我們的思路要清楚,無(wú)非就是找出相同的字符并統(tǒng)計(jì)他出現(xiàn)的次數(shù),我們保證每個(gè)字符只能出現(xiàn)偶數(shù)次,最多允許一個(gè)字符出現(xiàn)奇數(shù)個(gè)(奇數(shù)位字符串的中間元素)

代碼如下:

char Func(char* s)
{
	int  i, count = 0;
	int a[128] = { 0 };
	int sz = strlen(s);//計(jì)算字符數(shù)組長(zhǎng)度來(lái)作為循環(huán)判斷部分
	for (i = 0; i < sz; i++)
	{
		a[s[i]]++;//統(tǒng)計(jì)相同字符出現(xiàn)次數(shù),有點(diǎn)像哈希表
	}
	for (i = 0; i < 128; i++)
	{
		if (a[i] % 2 == 1)//判斷出現(xiàn)次數(shù)是否為偶數(shù)
			count++;
		if (count >= 2)//判斷是否最多存在一個(gè)出現(xiàn)奇數(shù)次的元素
			return false;
	}
	return true;
}

注意,這里面有一些重要細(xì)節(jié):

1.數(shù)組 s 為 char 類型,字符數(shù)組在內(nèi)存中存儲(chǔ)方式是ASCII碼值,s[ i ]就是在一一列舉其中元素,假如我收到一個(gè) ‘ a ’,a以ASCII碼值作為下標(biāo)++,第二個(gè)‘ a ’找到后依然是用相同的ASCII碼值作為下標(biāo)再++;這就是我統(tǒng)計(jì)數(shù)組中相同元素的次數(shù)的原理。

2. 數(shù)組初始化 a [128]不能更改是因?yàn)锳SCII碼值一共是128個(gè),0~127。

3.強(qiáng)調(diào)最多一位為奇數(shù)次出現(xiàn)的字符的特殊情況。

點(diǎn)殺回文驗(yàn)證(有效性)

這道題就是典型的指針對(duì)撞題,因?yàn)轭}目告訴考慮數(shù)字和字符,我們寫的時(shí)候就可以不考慮字符的大小寫,這種方法需要靈活使用庫(kù)函數(shù)。

需要先判斷字符串中的字符是字母或數(shù)字,若不是,就pass掉。在 C 語(yǔ)言中可以用 isalnum() 函數(shù)去判斷。

忽略字母的大小寫,所以可以將待比較的字符轉(zhuǎn)化為小寫或大寫,然后再比較。在 C 語(yǔ)言中可以用 tolower() 和 toupper() 函數(shù)。

對(duì)撞指針

一根指針指向頭,滿足條件時(shí),往右移動(dòng);一根指針指向尾,滿足條件時(shí),往左移動(dòng);最后兩根指針相遇,循環(huán)條件一般是前下標(biāo)(指針)小于后下標(biāo)(指針)。

送上代碼:

char Fun(char * s)
{
    int left = 0, right = strlen(s) - 1;
    while (left < right) 
    {       //篩選出數(shù)字與字符
        if (!isalnum(s[left])) {
            left++; 
        } else if (!isalnum(s[right])) {
            right--;
        } else { //合并為小寫(大寫)來(lái)判斷
            if (tolower(s[left]) != tolower(s[right])) {
                return false;
            }            
            left++;
            right--;
        }
    }
    return true;
    }         

今天就到這里了家人們,先摸了。

以上就是C語(yǔ)言算法打卡回文串驗(yàn)證算法題解的詳細(xì)內(nèi)容,更多關(guān)于C語(yǔ)言回文串算法驗(yàn)證的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Qt實(shí)現(xiàn)鬧鐘小程序

    Qt實(shí)現(xiàn)鬧鐘小程序

    這篇文章主要為大家詳細(xì)介紹了Qt實(shí)現(xiàn)鬧鐘小程序,利用Qt的designer設(shè)計(jì)需要的鬧鐘界面,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • C++利用VLC庫(kù)制作音視頻的示例代碼

    C++利用VLC庫(kù)制作音視頻的示例代碼

    這篇文章主要為大家詳細(xì)介紹了C++如何利用VLC庫(kù)制作音視頻,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的小伙伴可以了解一下
    2024-01-01
  • C++STL教程之vector模板的使用

    C++STL教程之vector模板的使用

    模板類vector是一個(gè)動(dòng)態(tài)數(shù)組,類似于string類,可存放任意類型,能夠末尾、中間增加數(shù)據(jù),基本上是是new創(chuàng)建動(dòng)態(tài)數(shù)組的替代品,vector可以自動(dòng)完成new和delete
    2022-08-08
  • OpenCV實(shí)現(xiàn)亂序碎片復(fù)原

    OpenCV實(shí)現(xiàn)亂序碎片復(fù)原

    這篇文章主要介紹了通過OpenCV 直方圖相似度對(duì)比,實(shí)現(xiàn)將4張打亂順序的碎片拼接復(fù)原并展示原圖。文中的示例代碼講解詳細(xì),需要的朋友可以學(xué)習(xí)一下
    2021-12-12
  • 簡(jiǎn)單介紹C++中變量的引用

    簡(jiǎn)單介紹C++中變量的引用

    這篇文章主要簡(jiǎn)單介紹了C++中變量的引用,是C++入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-09-09
  • C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之堆排序的優(yōu)化算法

    C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之堆排序的優(yōu)化算法

    堆排序Heap?Sort就是利用堆進(jìn)行排序的方法,下面這篇文章主要給大家介紹了關(guān)于C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之堆排序的優(yōu)化算法的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-04-04
  • OpenCV實(shí)現(xiàn)無(wú)縫克隆算法的步驟詳解

    OpenCV實(shí)現(xiàn)無(wú)縫克隆算法的步驟詳解

    借助無(wú)縫克隆算法,您可以從一張圖像中復(fù)制一個(gè)對(duì)象,然后將其粘貼到另一張圖像中,從而形成一個(gè)看起來(lái)無(wú)縫且自然的構(gòu)圖。本文將詳解OpenCV實(shí)現(xiàn)無(wú)縫克隆算法的步驟,需要的可以參考一下
    2022-06-06
  • 一篇文章帶你了解C++中的顯示轉(zhuǎn)換

    一篇文章帶你了解C++中的顯示轉(zhuǎn)換

    這篇文章主要介紹了C++11顯示類型轉(zhuǎn)換的優(yōu)點(diǎn),幫助大家更好的理解和學(xué)習(xí)c++,感興趣的朋友可以了解下,希望能給你帶來(lái)幫助
    2021-08-08
  • C++ stack與queue模擬實(shí)現(xiàn)詳解

    C++ stack與queue模擬實(shí)現(xiàn)詳解

    這篇文章主要給大家介紹了關(guān)于c++stack與queue模擬實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-08-08
  • C++深入探索類和對(duì)象之封裝及class與struct的區(qū)別

    C++深入探索類和對(duì)象之封裝及class與struct的區(qū)別

    C++?類與對(duì)象涉及的知識(shí)點(diǎn)非常廣泛,所以我準(zhǔn)備寫成幾個(gè)特定的部分來(lái)作為博文分享,這次的blog將詳細(xì)講解類的屬性、行為、訪問權(quán)限,class與struct的區(qū)別以及具體案例,希望能夠?qū)δ銈冇袔椭鉀Q入門小白或者對(duì)這方面了解不多的朋友們,那么接下來(lái)開始今天的內(nèi)容
    2022-05-05

最新評(píng)論