方法一:
#include <stdio.h> #include <stdlib.h> #include <string.h> void Reverse(char str[]); int main() { char str[100]; printf("Input a string:"); gets(str); Reverse(str); printf("Inversed results:%s\n",str); } void Reverse(char str[]){ int n=strlen(str); int i; char temp; for(i=0;i<(n/2);i++){ temp=str[i]; str[i]=str[n-i-1]; str[n-i-1]=temp; } } //思路:通過將str數組的第1個字符和第n個字符交換位置,第二個和第n-1個交換…實現該功能
方法二:
#include <stdio.h> #include <stdlib.h> #include <string.h> void Reverse(char str[], char ptr[]); int main() { char str[100]; char ptr[100]; printf("Input a string:"); gets(str); Reverse(str,ptr); printf("Inversed results:%s\n",ptr); } void Reverse(char str[], char ptr[]){ int n=strlen(str); int i; for(i=0;i<=n;i++){ ptr[i]=str[n-i-1]; } ptr[i-1]='\0'; } //思路:通過倒着遍歷數組str,並把遍歷結果存入ptr從而實現改功能
另外有一種不用新變量的方法:
char *reverse(char *str) { if(str==nullptr) return nullptr; int len=strlen(str); int i=0; while(i<len-i-1){ str[i]=str[i]^str[len-i-1]; str[len-i-1]=str[i]^str[len-i-1]; str[i]=str[i]^str[len-i-1]; i++; }; return str; }
參考:https://blog.csdn.net/m0_37888031/article/details/77896594