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

C語言刷題之倒置字符串的解題全過程

 更新時間:2023年02月20日 12:36:19   作者:C-調(diào)戰(zhàn)士  
這篇文章主要給大家介紹了關(guān)于C語言刷題之倒置字符串的解題全過程,這是一道我們經(jīng)常刷到的實戰(zhàn)題目,文中通過實例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下

先來看題

解題思路

?? 首先我們定義一個字符數(shù)組來存放字符串,然后用 gets函數(shù)來讀入字符串,接下來進行處理階段,設(shè)計一個逆序函數(shù)逆序整個字符串,然后再逆序每個單詞,最后處理一下細節(jié)再輸出

解題過程

1.輸入

定義完一個字符數(shù)組后,因為scanf不吃空格符和換行符,所以這里輸入我們采用gets函數(shù)來進行讀入字符串,看代碼??

int main()
{
	char arr[101] = { 0 };
	//輸入
	gets(arr);

2.設(shè)計逆序函數(shù)

看代碼??

void reverse(char* left, char* right)
{
	assert(*left != NULL);
	assert(*right != NULL);

	while (left < right)
	{
		char tmp = *left;
		*left = *right;
		*right = tmp;
		left++;
		right--;
	}
}

??字符串的首尾元素逐個進行交換(不包括\0)??

因為傳過來的是數(shù)組首元素地址,所以我們要用指針變量來接收,為了代碼更謹慎,這里使用了assert斷言,防止遇到空指針而導(dǎo)致程序運行錯誤(不能忘記引頭文件<assert.h>)

3.逆序整個字符串

	int len = strlen(arr);
	//逆序整個字符串
	reverse(arr, arr + len - 1);

??我們使用strlen函數(shù)來計算字符串元素個數(shù)(不要忘記引頭文件<string.h>),然后調(diào)用 reverse函數(shù)進行整個字符串的逆置。

??這里的 arr + len - 1是首元素地址+字符串長度(整數(shù))- 1 得到的是末尾元素的地址如果不 - 1指向的就是 ’\0‘了

4.逆序每個單詞

char* cur = arr;
	while (*cur)
	{
		//找一個單詞
		char* start = cur;
		while (*cur != ' ' && *cur != '\0')
		{
			cur++;
		}
		reverse(start, cur - 1);
		if (*cur == ' ')
		{
			cur++;
		}
	}

??定義一個指針變量cur來接收逆序整個字符串之后的arr數(shù)組首元素地址,然后如果cur指向的字符不是’\0’的話就進入循環(huán),然后再定義一個指針變量start來接收每個單詞的首元素地址,然后進入循環(huán)判斷如果cur指向的不是空格或者’\0’就往后跳一個字符,直到cur指向的是空格或者’\0‘了,就說明已經(jīng)遍歷完確認了一個單詞,然后進入reverse函數(shù) 來逆序單詞(cur - 1 是因為如果不 -1,cur指向的是空格或者’\0‘

??最后如果cur指向的是空格而不是’\0‘就說明還沒有結(jié)束,還有單詞沒有逆序完,往后跳一個字符循環(huán)繼續(xù)

??最后打印輸出

源碼

#include<stdio.h>
#include<string.h>
#include<assert.h>

void reverse(char* left, char* right)
{
	assert(*left != NULL);
	assert(*right != NULL);

	while (left < right)
	{
		char tmp = *left;
		*left = *right;
		*right = tmp;
		left++;
		right--;
	}
}
int main()
{
	char arr[101] = { 0 };
	//輸入
	gets(arr);
	//處理
	int len = strlen(arr);
	//逆序整個字符串
	reverse(arr, arr + len - 1);
	//逆序每個單詞
	char* cur = arr;
	while (*cur)
	{
		//找一個單詞
		char* start = cur;
		while (*cur != ' ' && *cur != '\0')
		{
			cur++;
		}
		reverse(start, cur - 1);
		if (*cur == ' ')
		{
			cur++;
		}
	}
	//打印
	printf("%s\n", arr);

	return 0;
}

總結(jié)

到此這篇關(guān)于C語言刷題之倒置字符串的文章就介紹到這了,更多相關(guān)C語言倒置字符串內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 基于Windows API實現(xiàn)遍歷所有文件并刪除的方法

    基于Windows API實現(xiàn)遍歷所有文件并刪除的方法

    這篇文章主要介紹了基于Windows API實現(xiàn)遍歷所有文件并刪除的方法,是win32應(yīng)用程序的一個比較典型的文件操作應(yīng)用技巧,需要的朋友可以參考下
    2015-04-04
  • 淺談頭文件algorithm中的常用函數(shù)

    淺談頭文件algorithm中的常用函數(shù)

    下面小編就為大家?guī)硪黄獪\談頭文件algorithm中的常用函數(shù)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • 詳解C語言進程同步機制

    詳解C語言進程同步機制

    這篇文章主要介紹了詳解C語言進程同步機制的的相關(guān)資料,文中代碼非常詳細,幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-06-06
  • Visual studio setup.exe 安裝vs2022報錯的解決方案

    Visual studio setup.exe 安裝vs2022報錯的解決方案

    這篇文章主要介紹了Visual studio setup.exe 安裝vs2022報錯的解決方案,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2024-01-01
  • C++ GetDlgItem用法案例詳解

    C++ GetDlgItem用法案例詳解

    這篇文章主要介紹了C++ GetDlgItem用法案例詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • C語言程序打豆豆(函數(shù)版)

    C語言程序打豆豆(函數(shù)版)

    今天小編就為大家分享一篇關(guān)于C語言程序打豆豆(函數(shù)版),小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-02-02
  • C++實現(xiàn)添加圖片水印到PDF文檔

    C++實現(xiàn)添加圖片水印到PDF文檔

    水印是顯示在文檔內(nèi)容后面的淡色文字或圖片,可以用于指示文檔的狀態(tài)(保密、草稿等),本文主要為大家介紹了如何使用?Spire.PDF?for?C++?在?PDF?文檔中添加圖片水印,需要的可以參考下
    2023-11-11
  • c語言求出給定范圍內(nèi)的所有質(zhì)數(shù)

    c語言求出給定范圍內(nèi)的所有質(zhì)數(shù)

    本文主要介紹了c語言求出給定范圍內(nèi)的所有質(zhì)數(shù)的小程序。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-04-04
  • C/C++ int數(shù)與多枚舉值互轉(zhuǎn)的實現(xiàn)

    C/C++ int數(shù)與多枚舉值互轉(zhuǎn)的實現(xiàn)

    在C/C++在C/C++的開發(fā)中經(jīng)常會遇到各種數(shù)據(jù)類型互轉(zhuǎn)的情況,本文主要介紹了C/C++ int數(shù)與多枚舉值互轉(zhuǎn)的實現(xiàn),具有一定的參考價值,感興趣的可以了解一下
    2021-08-08
  • 全排列算法的非遞歸實現(xiàn)與遞歸實現(xiàn)的方法(C++)

    全排列算法的非遞歸實現(xiàn)與遞歸實現(xiàn)的方法(C++)

    本篇文章是對全排列算法的非遞歸實現(xiàn)與遞歸實現(xiàn)的方法進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05

最新評論