編寫(xiě)一個(gè)函數(shù) reverse_string(char * string)(遞歸實(shí)現(xiàn))
實(shí)現(xiàn):將參數(shù)字符串中的字符反向排列,不是逆序打印。
要求:不能使用C函數(shù)庫(kù)中的字符串操作函數(shù)。
1、形參是數(shù)組void reverse_string(char arr[])//形參用數(shù)組接受,函數(shù)內(nèi)可以直接用下標(biāo)來(lái)訪(fǎng)問(wèn)數(shù)組元素
{
int l = 0;
int r = strlen(arr)-1;//數(shù)組下標(biāo)從0開(kāi)始,所以右下標(biāo)是字符串長(zhǎng)度減一,strlen是‘/0’之前的字符長(zhǎng)度
while (l< r)
{
char tmp = '0';
tmp = arr[l];//交換左右兩個(gè)數(shù)的值
arr[l] = arr[r];
arr[r] = tmp;
l++;//左下標(biāo)加1
r--;//右下標(biāo)減1
}
}
int main()
{
char arr[] = "abcdef";
printf("%s\n", arr);
reverse_string(arr);//字符串逆序
printf("%s\n", arr);
return 0;
}
2、形參是str指針int Strlen(char* str)
{
if (*(str) == 0)
return 0;
else
return 1 + Strlen(str + 1);//字符串長(zhǎng)度至少是1,然后再求下一個(gè)元素
}
void reverse_string(char* str)
{
int l = 0;
int r = Strlen(str) - 1;//sizeof(str)是指針的大小4/8,stlen(str)可以求字符串長(zhǎng)度,但不能使用C函數(shù)庫(kù)中的字符串操作函數(shù),所以自己寫(xiě)一個(gè)Strlen
//str是首元素地址,地址加1就是下一個(gè)元素地址,再進(jìn)行解引用操作即可交換元素
//數(shù)組在內(nèi)存中是連續(xù)存儲(chǔ)的,知道首元素地址就可以輕松的找到后面的元素
while (l< r)
{
char tmp = '0';
tmp = *(str + l);
*(str + l) = *(str + r);
*(str + r) = tmp;
l++;
r--;
}
}
int main()
{
char arr[] = "abcdef";
printf("%s\n", arr);
reverse_string(arr);//字符串逆序
printf("%s\n", arr);
return 0;
}
int Strlen(char* str)
{
if (*(str) == 0)
return 0;
else
return 1 + Strlen(str + 1);//字符串長(zhǎng)度至少是1,然后再求下一個(gè)元素
}
void reverse_string(char* str)
{
int l = 0;
int r = Strlen(str) - 1;//如果不減1,就指向了\0
if (l< r)
{
char tmp = '0';
tmp = *(str + l);
*(str + l) = *(str + r);
*(str + r) = '\0';//右元素先賦值為字符串的結(jié)束標(biāo)志,再去進(jìn)行reverse_string 遞歸
reverse_string(str + 1);
*(str + r) = tmp;//遞歸完成后恢復(fù)右元素的內(nèi)容
}
}
int main()
{
char arr[] = "abcdef";
printf("%s\n", arr);
reverse_string(arr);//字符串逆序
printf("%s\n", arr);
return 0;
}
4,要求輸入輸出void reverse(char* str)
{
char* left = str;
char* right = str + strlen(str) - 1;
while (left< right)
{
char tmp = *(left);
*(left) = *(right);
*(right) = tmp;
left++;
right--;
}
}
int main()
{
char arr[100] = "0";//只初始化arr[0]為0,其他默認(rèn)初始化為\0
//scanf("%s", arr);//錯(cuò)誤使用,因?yàn)閟canf通過(guò)%s讀取字符串時(shí),遇到空格會(huì)停止讀取
//scanf("%[^\n]", arr);//正確使用,意思是一直讀取字符串直到換行才停止讀取
gets(arr);//gets函數(shù)以回車(chē)結(jié)束讀取,存儲(chǔ)到arr中
reverse(arr);
printf("%s", arr);
return 0;
}
你是否還在尋找穩(wěn)定的海外服務(wù)器提供商?創(chuàng)新互聯(lián)www.cdcxhl.cn海外機(jī)房具備T級(jí)流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確流量調(diào)度確保服務(wù)器高可用性,企業(yè)級(jí)服務(wù)器適合批量采購(gòu),新人活動(dòng)首月15元起,快前往官網(wǎng)查看詳情吧
新聞標(biāo)題:【c語(yǔ)言】字符串逆序-創(chuàng)新互聯(lián)
當(dāng)前鏈接:http://newbst.com/article36/dgicsg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站營(yíng)銷(xiāo)、網(wǎng)站排名、網(wǎng)站改版、網(wǎng)站策劃、ChatGPT、動(dòng)態(tài)網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容
移動(dòng)網(wǎng)站建設(shè)知識(shí)