C语言 分析逆序字符串与字符串的逆序输出有什么区别

 更新时间:2022年04月14日 15:13:57   作者:ChaoFreeandeasy_  
例如,给定一个字符串 s,将 s 中的字符顺序颠倒过来,如 s = “abcd”,逆序后变成 “dcba”。可以采用多种方法对字符串进行逆序,以下将对其中的方法和字符串的逆序输出的区别进行分析

今天我们讲解字符串的逆序和逆序输出,并且通过一个综合题型来加深印象和练手!

前言

逆序字符串和字符串的逆序输出,可能经常会有人混淆,所以今天带大家一起来看一看吧!

一、字符串的逆序

字符串的逆序输出是什么?

逆序字符串:针对一个输入的字符串数组,通过逆序,将其数组内容进行翻转逆序。

字符串的逆序输出:对于一个字符串,只需要数组创建,然后求出字符串的长度,从字符串数组最后一个元素依次输出,直到第一个元素。即可完成字符串的逆序输出。

二、实例讲解

1.字符串的逆序输出

代码如下(示例):

#include<stdio.h>
#include<string.h>
int main()
{
 
char arr[]="1234567";
int i=0;
int sz=strlen(arr);
for(i=sz-1;i>=0;i--)
  {
  printf("%c",arr[i]);
  }
  return 0;
}

可以看出,在输入字符串以后,逆向打印出字符串数组的每一个元素,只需要要从数组的最后一个下标,即数组元素的个数减1,开始算起,到数组下标为0.输出即可!

2.逆序字符串

#include<stdio.h>
#include<string.h>
void reverse(char* left, char *right)
{
	while (left < right)
	{
		char temp = *left;
		*left = *right;
		*right = temp;
		left++;
		right--;
	}
 
}
int main()
{
	char arr[] = "1234567";
	int sz = strlen(arr);
	int i = 0;
	reverse(arr, arr+sz-1);
	for (i = 0; i < sz; i++)
	{
		printf("%c", arr[i]);
	}
	return 0;
}

通过reverse函数,将字符串内部逆置。

while (left < right)

    {

        char temp = *left;

        *left = *right;

        *right = temp;

        left++;

        right--;

    }

通过传址,将数组的首地址和元素的最后一个地址传到reverse函数中,通过解引用,交换其两端的值,来达到逆置字符串.

3.综合实例

 首先,看到题目后,我们应该分三步!!

1.将整个字符串进行倒置

.gnijieb ekil I

2.将每部分字符串倒置

beijing. like I

具体代码如下

void reverse(char* left, char* right)
{
	while (left < right)
	{
		char temp = *left;
	    *left = *right;        
		*right = temp;
		left++;
		right--;
	}
}
int main()
{
	char arr[100] = { 0 };
    //输入字符串
	gets(arr);     
	int sz = strlen(arr);
    //将字符串进行整体的倒置
	reverse(arr, arr + sz - 1);    
    //将部分字符串进行倒置
	char* start = arr;
	
	while (*start)
	{
		char* end = start;
		while (*end != ' ' && *end!='\0')
		{
			end++;
		}
		reverse(start, end - 1);
		if (*end == ' ')
		{
			start = end + 1;
		}
		else
		{
			start = end;
		}
	 	
	   }
	printf("%s", arr);
	return 0;
}

重难点:

(sz为字符串元素个数)

第二步为,对部分字符串进行倒置。

(第一部分为例)

while (*end != ' ' && *end!='\0')

{

            end++;

 }

不难看出,只要end一直增加,直到不为空格或者\0,就可以到达第一部分字符串末尾地址。

(以第一部分为例)

end起初和start地址相同,但是要判断是否为空格或者\0,需要先自增,再看是否满足while条件,当结束条件时,end此时指向空格的地址,所以需要减1,来确定第一部分的末尾地址

之后再利用reverse函数进行倒置。

当排序后,如果end此时指向空格的地址,则需要start=end+1,到达第二个部分,在进行倒置。

如果不为空格,则start=end; 

总结

分清楚倒置字符串,和字符串的倒置输出!

其次在最后一个题目中,需要注意字符串的首尾地址!

到此这篇关于Java 分析逆序字符串与字符串的逆序输出有什么区别的文章就介绍到这了,更多相关Java 逆序字符串内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 详解QT使用http通信的同步和异步

    详解QT使用http通信的同步和异步

    在Qt与Http通信的时候,会根据不同的情况使用同步或者异步的方式进行数据请求,下面我们就来深入了解一下http通信的同步和异步的相关知识,感兴趣的小伙伴可以了解下
    2023-12-12
  • C++学习之多态的使用详解

    C++学习之多态的使用详解

    这篇文章主要为大家详细介绍了C++中多态的机制以及使用,文中的示例代码讲解详细,对我们学习C++有一定的帮助,感兴趣的可以了解一下
    2022-06-06
  • C/C++使用过程中的溢出问题详解

    C/C++使用过程中的溢出问题详解

    在C/C++程序里有一类非常典型的问题,那就是:溢出问题,现在分别来分析一下常见的数组溢出,整数溢出,缓冲区溢出,栈溢出和指针溢出等,需要的朋友可以参考下
    2024-01-01
  • c++11&14-多线程要点汇总

    c++11&14-多线程要点汇总

    这篇文章主要介绍了c++11&14-多线程的使用方法,文中代码非常详细,方便大家更好的参考和学习,感兴趣的朋友快来了解下
    2020-06-06
  • C语言正则表达式详解 regcomp() regexec() regfree()用法详解

    C语言正则表达式详解 regcomp() regexec() regfree()用法详解

    C语言处理正则表达式常用的函数有regcomp()、regexec()、regfree()和regerror(),这里就为大家介绍一下,需要的朋友可以参考一下啊
    2018-04-04
  • C语言实现英文文本词频统计

    C语言实现英文文本词频统计

    这篇文章主要为大家详细介绍了C语言实现英文文本词频统计,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-03-03
  • C语言左旋字符串的三种实现方式

    C语言左旋字符串的三种实现方式

    本文章将使用三种思路实现字符串的左旋(循环移动,截取和拼接,逆序反转),文中通过代码示例和图文介绍的非常详细,具有一定的参考价值,需要的朋友可以参考下
    2024-03-03
  • C语言数据结构单链表接口函数全面讲解教程

    C语言数据结构单链表接口函数全面讲解教程

    这篇文章主要为大家介绍了C语言数据结构单链表所有接口函数的全面讲解教程,有需要朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2021-10-10
  • C语言中sizeof()与strlen()的区别详解

    C语言中sizeof()与strlen()的区别详解

    这篇文章主要给大家介绍了关于C语言中sizeof()与strlen()区别的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • C++11标准库bind函数应用教程

    C++11标准库bind函数应用教程

    bind函数定义在头文件functional中,可以将bind函数看做成一个通用的函数适配器,他接收一个可调用对象,生成一个新的可调用对象来"适应"原对象的参数列表。本文将带大家详细了解一下bind函数的应用详解
    2021-12-12

最新评论