移动字母(PTA-武理-C实验)

本题要求编写函数,将输入字符串的前3个字符移到最后。
函数接口定义:
void Shift( char s[] );

其中char s[]是用户传入的字符串,题目保证其长度不小于3;函数Shift须将按照要求变换后的字符串仍然存在s[]里。
裁判测试程序样例:
#include
#include

#define MAXS 10

void Shift( char s[] );

void GetString( char s[] ); /* 实现细节在此不表 */

int main()
{
char s[MAXS];

GetString(s);
Shift(s);
printf("%s\n", s);

return 0; 

}

/* 你的代码将被嵌在这里 */

输入样例:
abcdef

输出样例:
defabc

void Shift( char s[] )
{
    int i,j;char a[3];
    for(i=0;i<3;i++)
        a[i]=s[i];
    for(i=3;s[i];i++)
        s[i-3]=s[i];
    for(j=i-3,i=0;i<3;i++)
        s[j++]=a[i];
 }

或者

void Shift( char s[] )
{
    int i,j,l;char a[3],*p;
    p=&s[3];l=strlen(s);
    for(i=0;i<3;i++)
        a[i]=s[i];
    for(i=0;i<l-3;i++)
        s[i]=*(p+i);
    for(j=l-3,i=0;i<3;i++)
        s[j++]=a[i];
}

或者

void Shift( char s[] )
{
    int i,j,t,l=strlen(s);
    for(i=0;i<3;i++)
    {   t=s[0];
        for(j=0;j<l-1;j++)
             s[j]=s[j+1];
         s[l-1]=t;
    }      
}

你可能感兴趣的:(C语言武理PTA,c语言)