无名阁,只为技术而生。流水不争先,争的是滔滔不绝。

关于字符串反转,看这一篇就够了1

学习与成长 dancy 1年前 (2023-11-28) 234次浏览 已收录 0个评论 扫描二维码

关于字符串反转,看这一篇就够了

关于字符串反转,看这一篇就够了1

在C编程中,对字符串的操作是每个程序员必须要要掌握的技能,那如何快速实现字符串反转呢?下面提供几种思路。

方法1:使用指针

代码:

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

void reverseString(char* str) {
    int len = strlen(str);
    char* left = str;
    char* right = str + len - 1;
    while (left < right) {
        char tmp = *left;
        *left++ = *right;
        *right-- = tmp;
    }
}

int main() {
    char str[] = "hello";
    reverseString(str);
    printf("%s\n", str);
    return 0;
}

方法2:使用递归

代码:

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

void reverseString(char* str, int left, int right) {
    if (left >= right) return;
    char tmp = str[left];
    str[left] = str[right];
    str[right] = tmp;
    reverseString(str, left + 1, right - 1);
}

int main() {
    char str[] = "hello";
    int len = strlen(str);
    reverseString(str, 0, len - 1);
    printf("%s\n", str);
    return 0;
}

方法3:使用栈

代码:

#include <stdio.h>

#define MAX_LEN 100

void reverseString(char* str) {
    char stack[MAX_LEN];
    int len = 0;
    while (*str) {
        stack[len++] = *str++;
    }
    while (len > 0) {
        printf("%c", stack[--len]);
    }
    printf("\n");
}

int main() {
    char str[] = "hello";
    reverseString(str);
    return 0;
}

字符串反转的应用场景

实现字符串反转在编程中有很多应用场景,比如:

  • 字符串倒序输出:将输入的字符串反转后输出。
  • 字符串加密:将输入字符串反转后进行加密处理。
  • 字符串匹配:在某些字符串匹配算法中,字符串反转可以作为一种预处理手段,提高字符串匹配效率。
  • 数字转换:字符串反转也可以用于将数字转换为字符串,例如将数字12345反转为字符串54321。

wxParse 微信小程序 常用解析html的方法 实现示例1(图文详解)

喜欢 (0)
[]
分享 (0)
关于作者:
发表我的评论
取消评论

评论审核已启用。您的评论可能需要一段时间后才能被显示。

表情 贴图 加粗 删除线 居中 斜体 签到