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

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

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

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

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

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

1. 首先獲取原字符串的長度,申請一個長度+1的空間,因為還需要一個結(jié)束符。

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

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

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

5. 空格也需要放到臨時數(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){
?? ?// 獲取該字符串長度?
?? ?int length = strlen(s);
?? ?// 申請新的空間?
?? ?char* temp = (char*)malloc(sizeof(char)*(length+1));
?? ?// 結(jié)束符\0?
?? ?temp[length] = 0;
?? ?int i = 0;
?? ?while(i<length){
?? ??? ?// 單詞的起始位置?
?? ??? ?int start = i;
?? ??? ?// 找尋單詞,因為字符串中的單詞以空格間隔?
?? ??? ?while(i<length&&s[i]!=' '){
?? ??? ??? ?i++;
?? ??? ?}
?? ??? ?// 找到了一個單詞進行交換,將后邊的字符放到前邊?
?? ??? ?for(int j=start;j<i;j++){
?? ??? ??? ?// 將單詞從后往前放置到新的數(shù)組中實現(xiàn)單詞的逆序?
?? ??? ??? ?temp[j] = s[start+i-1-j];
?? ??? ?}
?? ??? ?// 處理空格?
?? ??? ?while(i<length&&s[i]==' '){
?? ??? ??? ?temp[i] = ' ';
?? ??? ??? ?i++;
?? ??? ?}
?? ?}?
?? ?return temp;?
}

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

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

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

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

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

4. 完成整個字符串的翻轉(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){
?? ?// 獲取該字符串長度?
?? ?int length = strlen(s);
?? ?int i = 0;
?? ?while(i<length){
?? ??? ?// 單詞的起始位置?
?? ??? ?int start = i;
?? ??? ?// 找尋單詞,因為字符串中的單詞以空格間隔?
?? ??? ?while(i<length&&s[i]!=' '){
?? ??? ??? ?i++;
?? ??? ?}
?? ??? ?// 雙指針?
?? ??? ?int left = start;
?? ??? ?int right = i-1;?
?? ??? ?// 雙指針法進行翻轉(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)

思路

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

代碼實現(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. 整個字符串顛倒*/
	len  = strlen(str);
	head = str;
	tail = str + len - 1;
	strReverse(head, tail);
	
	/*逐個單詞顛倒回來*/
	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

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

相關(guān)文章

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

最新評論