您好,登錄后才能下訂單哦!
eg:
有一個字符數組的內容為:"student a am i",
請你將數組的內容改為"i am a student".
要求:
不能使用庫函數。
只能開辟有限個空間(空間個數和字符串的長度無關)。
student a am i
i ma a tneduts
i am a student
代碼具體思想
1.將句子反轉(不管單詞拼寫順序)
2.將各個單詞分別反轉為正確順序
源代碼:
#include<stdio.h>
#include<stdlib.h>
void Reverse(char *left, char *right)//范圍反轉
{
char temp;
while (left < right)
{
temp = *left;
*left = *right;
*right = temp;
left++; right--;
}
}
int TheStrlen(char *str)。。求字符串長度
{
int count=0,i=0;
while (*(str + i)!='\0')
{
count++;
i++;
}
return count;
}
void ReverseEnd(char *str)
{
char *left = str;
char *right = str + TheStrlen(str) - 1;
char *p = str;
char *sta;
Reverse(left, right);
while (*p != '\0')//將具體單詞反轉
{
sta = p;
while (*p != ' '&&*p != '\0')
{
p++;
}//測單詞長度范圍
Reverse(sta, p - 1);//反轉單詞
if (*p == ' ')//跳轉至下一個單詞
{
p++;
}
}
}
int main()
{
char str[] = "i am a student";
ReverseEnd(str);
printf("%s\n", str);
system("pause");
return 0;
}
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。