字符串逆序 - 多种方法实现

article/2025/10/24 21:30:30

字符串逆序实现方法

  • 1. 借助额外数组
  • 2. 循环实现
    • 2.1 图解
    • 2.2 思路
    • 2.3 代码实现
  • 3. 递归实现1
  • 4. 递归实现2
    • 4.1 思路

对字符串进行逆序,以字符串abcdef为例

1. 借助额外数组

#include <stdio.h>
#include <string.h>int main() {char str[] = "abcdef";//求字符串的大小,包括'\0'在内int sz = strlen(str) + 1;//动态内存分配,申请一个大小为sz的字符数组char* p = (char*)malloc(sizeof(char) * sz);int i = 0;int j = 0;for (i = 0, j = sz - 2; j >= 0; i++, j--) {p[i] = str[j];}//为申请的字符数组添上字符'\0'p[i] = '\0';//拷贝回strcpy(str, p);printf("%s\n", str);return 0;
}

2. 循环实现

2.1 图解

字符串逆序循环.gif

2.2 思路

字符串可以理解为末尾带'\0的字符数组,可以通过数组下标访问字符串的单个字符。

  • 对字符串的逆序不包括其末尾的'\0
  • 一种方法是让处'\0'之外的字符中第一个与最后一个交换,第二个与倒数第二个字符交换,直到完成所有对称的字符的交换。
  • 定义两个变量: left记录数组做下标,从0开始; right记录数组右下标,从字符串长度-1开始。
  • 每次交换后left+1,right-1。
  • 循环交换结束条件:left大于等于right时结束循环。

2.3 代码实现

#include <stdio.h>
#include <stdio.h>void reverse_str(char* str, int left, int right);int main() {char str[] = "abcdef";int left = 0;int right = strlen(str) - 1;reverse_str(str, left, right);puts(str);return 0;
}
//
void reverse_str(char* str, int left, int right) {while (left < right) {char t = str[left];str[left] = str[right];str[right] = t;left++;right--;}
}

3. 递归实现1

思路:与循环实现的思路基本相同,只是实现方式通过函数自身调用自身实现。

//递归实现
#include <stdio.h>void reverse_str(char* str, int left, int right);
int my_strlen(char* str);int main() {char str[] = "abcdef";int left = 0;int right = my_strlen(str) - 1;reverse_str(str, left, right);printf("%s\n", str);return 0;
}
//逆序字符串
void reverse_str(char* str, int left, int right) {if (left < right) {char t = str[left];str[left] = str[right];str[right] = t;reverse_str(str, left + 1, right - 1);}
}
//求字符串长度
int my_strlen(char* str) {if (*str != '\0') {return 1 + my_strlen(str+1);}else {return 0;}
}

4. 递归实现2

4.1 思路

递归思想 - 把大的问题逐步缩小为小的问题。

  • 如字符串 abcdef
  • 逆序字符串abcdef
  1. 要逆序字符串abcdef,即是逆序a与f加上字符串bcde
  2. 若出现字符串bcdef位置必须先赋值为'\0'
  3. 就是说逆序a与f时,f位置不能立马储存字符 a,等到字符串bcde逆序完成之后f位置再储存a,故a需要先用临时字符变量t存放;而对字符a的位置没有限制,故字符a的位置可以直接存放字符b的值。
  • 逆序字符串bcde
  1. 要逆序字符串bcde,即是逆序b与c加上字符串cd
  • 字符串cd逆序
  • 停止逆序
  • 函数进行回调,完成全部逆序

这种思路不太好想,加油!

#include <stdio.h>void reverse_string(char* string);
int my_strlen(char* str);int main() {char str[20] = "abcdef";reverse_string(str);puts(str);return 0;
}
//字符串逆序
void reverse_string(char* string) {char t = *string;int len = my_strlen(string);*string = *(string + len - 1);*(string + len - 1) = '\0';if (my_strlen(string+1) >=2) {reverse_string(string + 1);}*(string + len - 1) = t;
}//求字符串长度
int my_strlen(char* str) {if (*str != '\0') {return 1 + my_strlen(str + 1);}else {return 0;}
}

END


http://chatgpt.dhexx.cn/article/k7wqk3AH.shtml

相关文章

字符串逆序的几种写法

字符串逆序的几种写法 提示&#xff1a;将字符串逆序与将其逆序打印出来是两码事&#xff0c;逆序是将内容倒着改变了&#xff0c;逆序打印虽然打印结果也是倒着的&#xff0c;不过储存字符串的数组内容并没有改变。 一、非递归写法 1. 将一个给定的字符串abcdef逆序 #incl…

字符串逆序(递归实现)

目录 一、代码实现&#xff1a; 二、代码逐步实现过程&#xff1a; 1、不用递归用循环方式实现&#xff1a; 1、使用库函数&#xff1a; 2、不使用库函数&#xff1a; &#xff08;1&#xff09;使用参数是数组的形式&#xff1a; &#xff08;2&#xff09;使用参数是指…

【C语言刷题】字符串逆序

目录 一、字符串逆序&#xff08;基础题&#xff09; 1.一个经典的错误&#xff0c;标准的零分 2.采用gets函数来修补漏洞 3.非要使用scanf怎么办&#xff1f; 4.使用指针来实现逆序函数 5.将函数修改为&#xff0c;只要传入两个地址&#xff0c;就能逆序这两个地址之间的…

使用C语言实现字符串逆序操作

这篇文章主要介绍了使用C语言实现字符串逆序操作案例,本文包含使用C语言的两种方法去实现,递归和非递归,以下就是详细内容,需要的朋友可以参考下 编写一个函数 reverse_string(char * string) 实现&#xff1a;将参数字符串中的字符反向排列。 要求&#xff1a;不能使用C函数库…

C语言实现——字符串逆序

目录 前言 如何实现 代码实现 1.设立一个数组存放输入的字符串 2.将输入的字符串整体逆序 2.1 计算字符串长度 2.2 使用函数来实现倒置 2.3 实现函数reverse 3.将其中每个单词再进行逆序 3.1 整个语句如何结束循环 3.2 每个单词的结束位置 3.3 内部实现 3.4 判断…

dtb展开成device_node

dtb展开成device_node 文章目录 dtb展开成device_node设备树是如何传递给内核的&#xff1f;设备树相关结构体举例of操作函数与查找节点有关的 OF 函数1、of_find_node_by_name 函数2、of_find_node_by_type 函数3、of_find_compatible_node 函数4、of_find_matching_node_and_…

设备树之DTS与DTB格式

目录 一、设备树 二、DTS格式 2.1 属性 2.2 节点 2.3 引用其他节点 2.4 小总结 三、DTB格式 3.1 结构 3.2 分析 一、设备树 对于点灯字符设备驱动程序可以有三种写法&#xff0c;首先是传统方法&#xff0c;这种方式直接在程序中写死&#xff0c;其次是利用总线设备驱…

Android boot.img dtb.img 编译过程

最近做RK3588案子,修改dts后,导致boot.img过大,编译出错,整体分析下boot.img过大的原因是因为在打包boot.img过程中,dbt.img过大导致,所以整体分析下boot.img编译过程,尤其是dbt.img的生成过程. boot.img生成过程 在Andorid跟目录下执行, source build/envsetup.sh 然后lunch x…

Linux 设备树(二) dtc dts/dtsi dtb的关系

在学习设备树之前&#xff0c;我们先来了解一下跟设备树相关的三个对象&#xff0c;分别是dtc、dts/dtsi、dtb。 dtc:用来编译设备树的工具 dts:设备树描述文件 dtsi:设备树头文件 dtb:编译后的二进制文件 dtc设备树编译工具 dtc是用来编译设备树的工具&#xff0c;就像gcc可以…

dtb如何转换到platform_device

分2步&#xff0c;第一步是首先转换为device_node&#xff0c;第二步device_node转换为platform_device。 第一步 /*** unflatten_device_tree - create tree of device_nodes from flat blob** unflattens the device-tree passed by the firmware, creating the* tree of st…

U-Boot 之一 零基础编译 U-Boot 过程详解、Image 镜像介绍及使用说明、DTB 文件使用说明

最近&#xff0c;工作重心要从裸机开发转移到嵌入式 Linux 系统开发&#xff0c;在之前的博文 Linux 之八 完整嵌入式 Linux 环境、&#xff08;交叉&#xff09;编译工具链、CPU 体系架构、嵌入式系统构建工具 中详细介绍了嵌入式 Linux 环境&#xff0c;接下来就是实际动手学…

dts、dtb的那些事儿

笔者最近在支持新的案子&#xff0c;过于忙碌&#xff0c;好久没更新了&#xff0c;勿怪。 1、设备树大变革故事 2011年3月17日的ARM Linux邮件列表有封邮件“this whole ARM thing is a fucking pain in the ass”引起了轩然大波&#xff0c;原来是我们的Linux之父Linus Torv…

DBT工具简介

What is DBT 在将数据加载到集中式数据仓库之前&#xff0c;必须对其进行清理、保持一致并根据需要进行组合。换句话说&#xff0c;必须转换数据&#xff0c;这就是我们所谓的 ETL&#xff08;提取、转换、加载&#xff09;和 ELT 中的“T”。 这是挖掘数据价值的关键一步。 而…

4.2uboot对设备树的支持——dtb的修改原理

本节说明在uboot中修改dtb的原理。 在uboot中&#xff0c;有一些命令支持对dtb文件进行修改。 当我们想要修改dtb文件时&#xff0c;可以直接修改dts文件&#xff0c;然后编译dts文件生成新的dtb文件&#xff0c;再将新的dtb文件载入设备。 或者&#xff0c;我们也可以在ubo…

DBT是什么

关于DBT DBT 是一种数据转换工作流&#xff0c;可帮助您完成更多工作&#xff0c;同时产生更高质量的结果。您可以使用 dbt 来模块化和集中分析代码&#xff0c;同时还为数据团队提供软件工程工作流中常见的护栏。在将数据模型安全部署到生产环境之前&#xff0c;通过监控和可见…

2.1设备树的规范(dts和dtb)——DTS格式

本节学习设备树的规范。 使用设备树时&#xff0c;需要编写dts文件&#xff0c;然后使用dtc编译dts文件&#xff0c;生成dtb文件。 所以本节分为两部分&#xff0c;第一部分讲解dts格式&#xff0c;第二部分讲解dtb格式。 首先看一下dts文件的布局。 DTS文件布局&#xff0…

关于EMUELC适配各种机型,DTB如何修改教程

很多爱好者留言&#xff0c;都想问关于EMUELC的dtb适配机型问题&#xff0c;这里我就出一个教程&#xff0c;如何修改dtb&#xff0c;然后去适配自己的机型&#xff0c;然后启动 。这里我只是提供方法&#xff0c;具体的调试是需要原理图进行配置。 首先&#xff0c;不管是aml…

DTBO简介

1、DTBO简介 设备树 (DT) 是用于描述“不可发现”硬件的命名节点和属性构成的一种数据结构。操作系统&#xff08;例如在 Android 中使用的 Linux 内核&#xff09;会使用 DT 来支持 Android 设备使用的各种硬件配置。硬件供应商会提供自己的 DT 源文件&#xff0c;接下来…

【DTB/DTBO 分区介绍】

如果你的 DTB/DTBO 位于专属的分区&#xff08;例如 dtb 和 dtbo 分区&#xff09;中&#xff0c;请使用以下表格结构和头文件格式&#xff1a; 数据结构 dt_table_header 仅适用于 dtb/dtbo 分区&#xff1b;您不能在kernel( image.gz) 末尾处附加此格式。如果您有一个 DTB/D…

2.2设备树的规范(dts和dtb)——DTB格式

本节讲述设备树的dtb格式。 上节讲述了dts格式。回顾上节&#xff0c;在dts文件和dtsi文件中&#xff0c;可以使用C语言的define和include&#xff0c;使用方法和作用也同C语言相同。 编写dts文件后&#xff0c;需要使用dtc工具将dts文件编译成dtb文件。dtc工具可以检查dts文…