溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

將參數(shù)字符串中的字符反向排列

發(fā)布時(shí)間:2020-07-20 19:12:46 來(lái)源:網(wǎng)絡(luò) 閱讀:494 作者:小楊楊雪松 欄目:編程語(yǔ)言
//編寫一個(gè)函數(shù)reverse_string(char * string)(遞歸實(shí)現(xiàn))
//實(shí)現(xiàn):將參數(shù)字符串中的字符反向排列。
//要求:不能使用C函數(shù)庫(kù)中的字符串操作函數(shù)。

//第一種方法:遞歸法
#include <stdio.h>
int reverse_string(char * string)
{
 if (*string != '\0')
 {
  string++;
  reverse_string(string);
  printf("%c", *(string-1));
 }
}
int main()
{
 char *string = "abcde";
 printf("源字符串為:%s\n", string);
 printf("反向排列后為:");
 reverse_string(string);
 printf("\n");
 return 0;
}


//第二種方法:
#include <stdio.h>
#include <assert.h>
#include<string.h>
char *reverse(char *str,int len)
{
 int i = 0;
 char *start = str;
 char *end = str + len - 1;
 char tmp ;
 assert(str);
 while (start < end)
 {
  tmp = *start;
  *start = *end;
  *end = tmp;
  start++;
  end--;
 }
 
 return str;
}
int main()
{
 char p[] = "abcdef";
 int len = strlen(p);
    printf("%s\n", reverse(p,len));
 return 0;
}


向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI