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

C語言如何實(shí)現(xiàn)翻轉(zhuǎn)字符串中的單詞

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

C語言翻轉(zhuǎn)字符串中的單詞

另外開辟一個(gè)空間,來存放翻轉(zhuǎn)的字符串

單詞之間是以空格間隔的,所以我們翻轉(zhuǎn)需要一個(gè)一個(gè)字符進(jìn)行翻轉(zhuǎn),我們需要找尋空格,找到空格表示一個(gè)字符已經(jīng)找到,進(jìn)行以下的步驟:

1. 首先獲取原字符串的長(zhǎng)度,申請(qǐng)一個(gè)長(zhǎng)度+1的空間,因?yàn)檫€需要一個(gè)結(jié)束符。

2. 定義一個(gè)變量i,初始化為0,用i進(jìn)行字符串的遍歷,定義一個(gè)start用來表示每個(gè)單詞的起始位置。

3. 遍歷字符串,不是空格i++,直到遇見空格,表示找到了一個(gè)單詞。

4. 將該單詞從末尾放到咱們新開辟的數(shù)組中,就實(shí)現(xiàn)了逆序。

5. 空格也需要放到臨時(shí)數(shù)組中保持與原數(shù)組一致。

#include<stdio.h>
#include<string.h>
char * reverseWords(char * s);
int main(){
?? ?char s[] = "Let's pass the examination";
?? ?char *temp = reverseWords(s);
?? ?printf("%s",temp);
?? ?return 0;
}?
char * reverseWords(char * s){
?? ?// 獲取該字符串長(zhǎng)度?
?? ?int length = strlen(s);
?? ?// 申請(qǐng)新的空間?
?? ?char* temp = (char*)malloc(sizeof(char)*(length+1));
?? ?// 結(jié)束符\0?
?? ?temp[length] = 0;
?? ?int i = 0;
?? ?while(i<length){
?? ??? ?// 單詞的起始位置?
?? ??? ?int start = i;
?? ??? ?// 找尋單詞,因?yàn)樽址械膯卧~以空格間隔?
?? ??? ?while(i<length&&s[i]!=' '){
?? ??? ??? ?i++;
?? ??? ?}
?? ??? ?// 找到了一個(gè)單詞進(jìn)行交換,將后邊的字符放到前邊?
?? ??? ?for(int j=start;j<i;j++){
?? ??? ??? ?// 將單詞從后往前放置到新的數(shù)組中實(shí)現(xiàn)單詞的逆序?
?? ??? ??? ?temp[j] = s[start+i-1-j];
?? ??? ?}
?? ??? ?// 處理空格?
?? ??? ?while(i<length&&s[i]==' '){
?? ??? ??? ?temp[i] = ' ';
?? ??? ??? ?i++;
?? ??? ?}
?? ?}?
?? ?return temp;?
}

直接在原數(shù)組上進(jìn)行操作

使用雙指針進(jìn)行單詞的翻轉(zhuǎn),一個(gè)指向單詞的開始,一個(gè)指向單詞的末尾。與上述方方法幾乎一致,只是交換的時(shí)候發(fā)生了一些變化。

1. 先通過空格找尋單詞。

2. 然后通過雙指針實(shí)現(xiàn)單詞翻轉(zhuǎn)。

3. 繼續(xù)遍歷字符串,空格跳過。

4. 完成整個(gè)字符串的翻轉(zhuǎn)。

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
char * reverseWords(char * s);
int main(){
?? ?char s[] = "Let's pass the examination";
?? ?char *temp = reverseWords(s);
?? ?printf("%s",temp);
?? ?return 0;
}?
char * reverseWords(char * s){
?? ?// 獲取該字符串長(zhǎng)度?
?? ?int length = strlen(s);
?? ?int i = 0;
?? ?while(i<length){
?? ??? ?// 單詞的起始位置?
?? ??? ?int start = i;
?? ??? ?// 找尋單詞,因?yàn)樽址械膯卧~以空格間隔?
?? ??? ?while(i<length&&s[i]!=' '){
?? ??? ??? ?i++;
?? ??? ?}
?? ??? ?// 雙指針?
?? ??? ?int left = start;
?? ??? ?int right = i-1;?
?? ??? ?// 雙指針法進(jìn)行翻轉(zhuǎn)?
?? ??? ?while(left<right){
?? ??? ??? ?char temStr = s[left];
?? ??? ??? ?s[left] = s[right];
?? ??? ??? ?s[right] = temStr;
?? ??? ??? ?left++;
?? ??? ??? ?right--;
?? ??? ?}
?? ??? ?// 空格忽略?
?? ??? ?while (i<length && s[i]==' ') {
? ? ? ? ? ? i++;
? ? ? ? }
?? ?}?
?? ?return s;?
}

C語言字符串各單詞的反轉(zhuǎn)

思路

我們首先把字符串整個(gè)反轉(zhuǎn),然后在逐個(gè)單詞反轉(zhuǎn)回來,每個(gè)單詞通過空格' '分隔開

代碼實(shí)現(xiàn)

int strReverse(char * head, char * tail){
	if(NULL == head || NULL == tail){
		printf("strReverse param error!\n");
		return PARAM_ERR;
	}
	
	char tmp;
 
	while(head < tail){
		tmp = *head;
		*head = *tail;
		*tail = tmp;
 
		head++;
		tail--;
	}
	
	return SUCCESS;
}
 
int strReversWithoutWord (char * str){
	if(NULL == str){
		printf("strReverse param error!\n");
		return PARAM_ERR;
	}
 
	int len = 0;
	char * head = NULL, * tail = NULL;
	char * p = NULL, * q = NULL;
 
	/*1. 整個(gè)字符串顛倒*/
	len  = strlen(str);
	head = str;
	tail = str + len - 1;
	strReverse(head, tail);
	
	/*逐個(gè)單詞顛倒回來*/
	p = str;
	while(*p != '\0'){
		head = p;
		q = p;
		while(' ' != *q && '\0' != *q){
			q++;
		}
		tail = q - 1;
		strReverse(head, tail);
		
		p = q + 1;
	}
}
 
void testReverse(void){
	char str[100] = "Feng is from Beijing!";
	char * head = NULL, * tail = NULL;
	int len  = 0;
 
	printf("\n************  testReverse ************ \n");
 
	strReversWithoutWord(str);
	printf("Reverse string without word is : %s\n\n", str);
 
	return;
}

代碼編譯

gcc main.c str.c -g -o a.exe

調(diào)試輸出

************  testReverse ************
 
Reverse string without word is : Beijing! from is Feng

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

相關(guān)文章

  • C語言修煉之路一朝函數(shù)思習(xí)得?模塊思維世間生上篇

    C語言修煉之路一朝函數(shù)思習(xí)得?模塊思維世間生上篇

    函數(shù)是一組一起執(zhí)行一個(gè)任務(wù)的語句。每個(gè)?C?程序都至少有一個(gè)函數(shù),即主函數(shù)?main()?,所有簡(jiǎn)單的程序都可以定義其他額外的函數(shù)
    2022-03-03
  • C++數(shù)據(jù)結(jié)構(gòu)之紅黑樹的實(shí)現(xiàn)

    C++數(shù)據(jù)結(jié)構(gòu)之紅黑樹的實(shí)現(xiàn)

    紅黑樹在表意上就是一棵每個(gè)節(jié)點(diǎn)帶有顏色的二叉搜索樹,并通過對(duì)節(jié)點(diǎn)顏色的控制,使該二叉搜索樹達(dá)到盡量平衡的狀態(tài)。本文主要為大家介紹了C++中紅黑樹的原理及實(shí)現(xiàn),需要的可以參考一下
    2022-08-08
  • C語言實(shí)現(xiàn)簡(jiǎn)單三子棋游戲

    C語言實(shí)現(xiàn)簡(jiǎn)單三子棋游戲

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)簡(jiǎn)單三子棋游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • C語言排序算法之桶排序解析

    C語言排序算法之桶排序解析

    這篇文章主要介紹了C語言排序算法之桶排序解析,桶排序Bucket?sort或所謂的箱排序,是一個(gè)排序算法,工作的原理是將數(shù)組分到有限數(shù)量的桶里,每個(gè)桶再分別排序,大部分是在分桶時(shí),即插入時(shí)就排序了,需要的朋友可以參考下
    2023-10-10
  • C語言中pthread_create函數(shù)實(shí)現(xiàn)向線程函數(shù)傳遞參數(shù)

    C語言中pthread_create函數(shù)實(shí)現(xiàn)向線程函數(shù)傳遞參數(shù)

    本文主要介紹了C語言中pthread_create函數(shù)實(shí)現(xiàn)向線程函數(shù)傳遞參數(shù),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • 談?wù)凜語言中位運(yùn)算你要知道的那些事兒

    談?wù)凜語言中位運(yùn)算你要知道的那些事兒

    C語言中的各種運(yùn)算都是以字節(jié)的形式進(jìn)行,在編寫很多系統(tǒng)程序時(shí),如驅(qū)動(dòng)程序、磁盤文件管理程序等,常要求將數(shù)據(jù)按位(bit)進(jìn)行運(yùn)算或者處理,下面這篇文章主要給大家介紹了關(guān)于C語言中位運(yùn)算的相關(guān)資料,需要的朋友可以參考下
    2022-02-02
  • C++實(shí)現(xiàn)聊天程序

    C++實(shí)現(xiàn)聊天程序

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)類似QQ聊天程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • 基于C語言實(shí)現(xiàn)計(jì)算生辰八字五行的示例詳解

    基于C語言實(shí)現(xiàn)計(jì)算生辰八字五行的示例詳解

    生辰八字,簡(jiǎn)稱八字,是指一個(gè)人出生時(shí)的干支歷日期;年月日時(shí)共四柱干支,每柱兩字,合共八個(gè)字。這篇文章主要介紹了C語言實(shí)現(xiàn)計(jì)算生辰八字五行的示例代碼,需要的可以參考一下
    2023-03-03
  • 簡(jiǎn)單介紹C++編程中派生類的析構(gòu)函數(shù)

    簡(jiǎn)單介紹C++編程中派生類的析構(gòu)函數(shù)

    這篇文章主要介紹了C++編程中派生類的析構(gòu)函數(shù),析構(gòu)函數(shù)平時(shí)一般使用較少,需要的朋友可以參考下
    2015-09-09
  • 利用C語言如何實(shí)現(xiàn)一些簡(jiǎn)單圖形的打印

    利用C語言如何實(shí)現(xiàn)一些簡(jiǎn)單圖形的打印

    這篇文章主要給大家介紹了關(guān)于利用C語言如何實(shí)現(xiàn)一些簡(jiǎn)單圖形的打印的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12

最新評(píng)論