亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C語(yǔ)言指針如何實(shí)現(xiàn)字符串逆序反轉(zhuǎn)

 更新時(shí)間:2022年07月20日 16:46:51   作者:xiaoyaolangwj  
這篇文章主要介紹了C語(yǔ)言指針如何實(shí)現(xiàn)字符串逆序反轉(zhuǎn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

指針實(shí)現(xiàn)字符串逆序反轉(zhuǎn)

#include<stdio.h>
#include<string.h> 
 
void rec(char* arr)
{
	//int len = sizeof(arr);  // 判斷字符串長(zhǎng)度需要用strlen。
	int len = strlen(arr);
	printf("字符串長(zhǎng)度len = %d\n", len);
	char* p1 = arr;
	char* p2 = &arr[len - 1];
	while (p1 < p2)
	{
		char temp = *p1;
		*p1 = *p2;
		*p2 = temp;
		p1++;
		p2--;
	}
}
 
int main()
{
	char arr[] = "hello world";
	rec(arr); 
	printf("逆序之后輸出為:%s\n", arr);
	system("pause");
	return 0;
}

知識(shí)點(diǎn)

  • 判斷字符串長(zhǎng)度需要用到string.h下的strlen函數(shù)方法。
  • 算法層面:

逆序就是頭尾逐位交換,所以選定兩個(gè)指針,一個(gè)在首,一個(gè)在尾。

指針可以直接比較大小。所以才有了while(p1<p2)來(lái)將算法執(zhí)行的終點(diǎn)找到。

  • 因?yàn)閭魅牒瘮?shù)方法rec的是地址,所以可以直接修改了原始數(shù)據(jù)。為了如果為了保護(hù)原始數(shù)據(jù),需要復(fù)制一份另用。

字符串逆序的幾種寫法

提示:將字符串逆序與將其逆序打印出來(lái)是兩碼事,逆序是將內(nèi)容倒著改變了,逆序打印雖然打印結(jié)果也是倒著的,不過(guò)儲(chǔ)存字符串的數(shù)組內(nèi)容并沒(méi)有改變。

非遞歸寫法

1. 將一個(gè)給定的字符串a(chǎn)bcdef逆序

#include <stdio.h>
int main()
{
	char arr[] = "abcdef";
	int sz = sizeof(arr) / sizeof(arr[0]); //求的是數(shù)組包含的元素個(gè)數(shù),'\0'也包括在內(nèi)
	int left = 0;
	int right = sz - 2;   //減2是因?yàn)榍蟮玫膕z包含了'\0'這個(gè)元素。
	while (left < right)
	{
		char tmp = arr[left];
		arr[left] = arr[right];
		arr[right] = tmp;
		left++;
		right--;
	}
	printf("%s", arr);
	return 0;
}

打印結(jié)果為fedcba。

逆序思路為:將一字符串最左端與最右端的字符交換,交換過(guò)后,通過(guò)數(shù)組下標(biāo)將左邊第二個(gè)字符與右邊第二個(gè)字符交換,依次類推,知道數(shù)組下標(biāo)通過(guò)left++與right–,使得left>=right。

2. 自己輸入一串字符串,將其逆序

#include <stdio.h>
#include <string.h>
int main()
{
	char arr[101] = { 0 };     //要給字符數(shù)組一定的內(nèi)存大小,如果寫成char arr[] = { 0 };,當(dāng)在給數(shù)組輸入的時(shí)候就會(huì)造成越界訪問(wèn)。
	scanf("%s", arr);
	int sz = strlen(arr);    //在給定字符數(shù)組的大小為101的情況下,只能用strlen求輸入字符串長(zhǎng)度。
                           //用sizeof(arr)/sizeof(arr[0])求出來(lái)的是數(shù)組大小,為101。
	int left = 0;
	int right = sz - 1;
	while (left < right)
	{
		char tmp = arr[left];
		arr[left] = arr[right];
		arr[right] = tmp;
		left++;
		right--;
	}
	printf("%s", arr);
	return 0;
}

隨便輸入一串字符,例如:12345gf,打印結(jié)果為fg54321。

注意:對(duì)于自己給數(shù)組輸入數(shù)據(jù),再將其逆序這種情況下,在定義數(shù)組時(shí),要給字符數(shù)組一定的內(nèi)存大小。如果寫成char arr[] = { 0 };,說(shuō)明這個(gè)數(shù)組的容量只有一個(gè)字節(jié),只能輸入一個(gè)字符,當(dāng)在給數(shù)組輸入的時(shí)候就會(huì)造成越界訪問(wèn)。

3. 將逆序封裝成函數(shù)

#include <stdio.h>
#include <string.h>
void reverse(char arr[])
{
	
	int left = 0;
	int right = strlen(arr) - 1;      //封裝成函數(shù)只能用庫(kù)函數(shù)求字符串長(zhǎng)度,不能用sizeof(arr)/sizeof(arr[0])-1這種方式。
                                    //因?yàn)閿?shù)組形參就是個(gè)地址。sizeof(arr)與sizeof(arr[0])的大小都是四個(gè)字節(jié)或者八個(gè)字節(jié)。
	while (left < right)
	{
		char tmp = arr[left];
		arr[left] = arr[right];
		arr[right] = tmp;
		left++;
		right--;
	}
}
int main()
{
	char arr[] = "abcdef";
	reverse(arr);
	printf("%s", arr);
	return 0;
}

與sizeof 兩者用來(lái)求字符串長(zhǎng)度時(shí)的場(chǎng)合區(qū)別。

這里值得注意的是,在自定義函數(shù)中求字符串長(zhǎng)度時(shí),不要用sizeof(arr)/sizeof(arr[0])-1這種方式。直接使用庫(kù)函數(shù) strlen。因?yàn)閿?shù)組在傳參的時(shí)候,傳過(guò)去的是數(shù)組首元素的地址,也就是說(shuō)形參雖說(shuō)寫的是數(shù)組的形式char arr[],但是形參其實(shí)是個(gè)指針變量char*。

對(duì)于指針變量來(lái)說(shuō),其大小根據(jù)編譯器環(huán)境,都是四個(gè)字節(jié)或者都是八個(gè)字節(jié)。sizeof運(yùn)算符就是獲取數(shù)據(jù)類型和表達(dá)式的尺寸的(單位:字節(jié))。sizeof(arr)與sizeof(arr[0])的大小都是四個(gè)字節(jié)或者八個(gè)字節(jié)。

所以sizeof(arr)/sizeof(arr[0])-1=4/4-1=0,或者8/8-1=0。

遞歸寫法

1. 方法一

#include <stdio.h>
#include <string.h>
void reverse(char str[])  //用數(shù)組接收實(shí)參,也可用指針接收實(shí)參,如void reverse(char* str) 
{
	char tmp = *str;
	int len = strlen(str);
	*str = *(str + len - 1);
	*(str + len - 1) = '\0';
	if (strlen(str + 1) >= 2)  //首尾交換后,剩下的元素構(gòu)成的數(shù)組,長(zhǎng)度要大于1,才逆序,只剩下一個(gè)元素,表明其是最中間的元素,放在原位就好。
	{
		reverse(str + 1);
	}
	*(str + len - 1) = tmp;
}
int main()
{
	char arr[101] = { 0 };
	scanf("%s", arr);
	reverse(arr);
	printf("%s\n", arr);
	return 0;
}

思路:假設(shè)一個(gè)數(shù)組有 n 個(gè)元素。

交換str[0]與 str[n-1],再逆序 str[1] 與 str[n-2]

交換 str[1] 與 str[n-2],再逆序 str[2] 與 str[n-3]。依次類推

······

操作步驟:

  • 1.先將第一個(gè)字符,即 str[0] 位置上的字符放在一個(gè)臨時(shí)變量中。
  • 2.將最后一個(gè)元素交換到 str[0] 的位置去。
  • 3.將字符串中的’\0’放到arr[n-1] 的位置上去。
  • 4.此時(shí)從 str[1] 到 str[n-2] 的角度上看,是一個(gè)新的字符串,將 str[1] 與 str[n-2] 交換。
  • 5.將先前放在臨時(shí)變量中的第一個(gè)字符賦給 arr[n-1] 的位置上去。

注意:在第三步并沒(méi)有將放在臨時(shí)變量中的第一個(gè)字符直接往 str[n-1]上放,而是經(jīng)過(guò)第四步,將str[1] 與 str[n-2] 交換后,才將之前未交換完的第一個(gè)字符放到 str[n-1] 上去。原因:如果直接將 str[0] 與 str[n-1] 上的元素通過(guò)一個(gè)臨時(shí)變量交換了。那么對(duì)于即將要交換的 str[1] 與 str[n-2] 來(lái)說(shuō),他們與’\0’之間隔了一個(gè)放在str[n-1]上的第一個(gè)字符,str[1] 與 str[n-2] 也就無(wú)法通過(guò)首尾字符直接交換的方式進(jìn)行交換了 。

逆序a b c d e f 等于交換 a與f ,再逆序b c d e

逆序b c d e 等于交換b與e,再逆序c d。依次類推。

2. 方法二

#include <stdio.h>
#include <string.h>
void reverse(char str[], int left, int right)
{
	if (left < right)
	{
		char tmp = str[left];
		str[left] = str[right];
		str[right] = tmp;
		reverse(str, left + 1, right - 1);
	}
}
int main()
{
	char arr[101] = { 0 };
	scanf("%s", arr);
	int left = 0;
	int right = strlen(arr) - 1;
	reverse(arr, left, right);
	printf("%s\n", arr);
	return 0;
}

方法二比方法一傳的參數(shù)要多,直接將首尾字符通過(guò)第三個(gè)臨時(shí)變量進(jìn)行交換就行。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 淺談C語(yǔ)言結(jié)構(gòu)體

    淺談C語(yǔ)言結(jié)構(gòu)體

    本文主要介紹C語(yǔ)言 結(jié)構(gòu)體的知識(shí),學(xué)習(xí)C語(yǔ)言肯定需要學(xué)習(xí)結(jié)構(gòu)體,這里詳細(xì)說(shuō)明了結(jié)構(gòu)體并附示例代碼,供大家參考學(xué)習(xí),有需要的小伙伴可以參考下
    2021-10-10
  • C語(yǔ)言文件讀寫操作介紹與簡(jiǎn)單示例

    C語(yǔ)言文件讀寫操作介紹與簡(jiǎn)單示例

    這篇文章主要給大家介紹了關(guān)于C語(yǔ)言文件讀寫操作的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • 解析C/C++指針、函數(shù)、結(jié)構(gòu)體、共用體

    解析C/C++指針、函數(shù)、結(jié)構(gòu)體、共用體

    這篇文章主要介紹了C/C++指針、函數(shù)、結(jié)構(gòu)體、共用體的相關(guān)知識(shí),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-01-01
  • 詳解圖的應(yīng)用(最小生成樹(shù)、拓?fù)渑判?、關(guān)鍵路徑、最短路徑)

    詳解圖的應(yīng)用(最小生成樹(shù)、拓?fù)渑判?、關(guān)鍵路徑、最短路徑)

    這篇文章主要介紹了圖的應(yīng)用(最小生成樹(shù)、拓?fù)渑判颉㈥P(guān)鍵路徑、最短路徑),需要的朋友可以參考下
    2015-08-08
  • C語(yǔ)言之包含min函數(shù)的棧實(shí)例詳解

    C語(yǔ)言之包含min函數(shù)的棧實(shí)例詳解

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言之包含min函數(shù)的棧,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-02-02
  • VsCode配置C++/Cmake的步驟詳解

    VsCode配置C++/Cmake的步驟詳解

    本文分步驟給大家介紹VsCode配置C++/Cmake的方法,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2021-07-07
  • 老生常談C++的單例模式與線程安全單例模式(懶漢/餓漢)

    老生常談C++的單例模式與線程安全單例模式(懶漢/餓漢)

    下面小編就為大家?guī)?lái)一篇老生常談C++的單例模式與線程安全單例模式(懶漢/餓漢)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-12-12
  • 解析C++編程中如何使用設(shè)計(jì)模式中的狀態(tài)模式結(jié)構(gòu)

    解析C++編程中如何使用設(shè)計(jì)模式中的狀態(tài)模式結(jié)構(gòu)

    這篇文章主要介紹了如何在C++編程中適用設(shè)計(jì)模式中的狀態(tài)模式結(jié)構(gòu),狀態(tài)模式強(qiáng)調(diào)將特定狀態(tài)相關(guān)的邏輯分散到一些類的狀態(tài)類中,需要的朋友可以參考下
    2016-03-03
  • 解析C++類內(nèi)存分布

    解析C++類內(nèi)存分布

    本篇文章介紹了C++類內(nèi)存分布結(jié)構(gòu),我們來(lái)看看編譯器是怎么處理類成員內(nèi)存分布的,特別是在繼承、虛函數(shù)存在的情況下
    2021-06-06
  • C++實(shí)現(xiàn)簡(jiǎn)單BP神經(jīng)網(wǎng)絡(luò)

    C++實(shí)現(xiàn)簡(jiǎn)單BP神經(jīng)網(wǎng)絡(luò)

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)簡(jiǎn)單BP神經(jīng)網(wǎng)絡(luò),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-05-05

最新評(píng)論