本题要求编写函数,将输入字符串的前3个字符移到最后。
函数接口定义:
void Shift( char s[] );
其中char s[]是用户传入的字符串,题目保证其长度不小于3;函数Shift须将按照要求变换后的字符串仍然存在s[]里。
裁判测试程序样例:
#include <stdio.h>
#include <string.h>
#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[] )
{
char b[3];
int n=strlen(s)-1;
for(int i=0;i<3;i++)
b[i]=s[i];
for(int j=0;j<=n-3;j++)
s[j]=s[j+3];
for(int k=0;k<3;k++)
s[n-2+k]=b[k];
}
回顾时,写的代码
void Shift( char s[] )
{
int i,j;
for(i=0;i<3;i++)
{
char b=s[0];
for(j=0;s[j+1]!='\0';j++)//字符串在你输入最后一个字符时,后面还有一个特殊字符(暂且称为特殊字符),即“\0”,电脑输出字符串时,遇到\0,就会停止输出,
//循环结束时j的值为最后一个字符的下标值。
s[j]=s[j+1];
s[j]=b;
}
}
对比两种,当然是后面那种比较好,代码量少,而且运行时间也比较短。