|
前两天参加了福富在福大的宣讲会,并且参加了笔试,最后一道大题,这里讲一下当时我的解法,大概的题意是这个样子的,只能使用c的库,实现一个函数void MakeString(char *pStr,int n)(ps:这里的函数名是我现在取的,想不起来考题给的是什么了),函数要求是以'\0'结尾的字符串pStr,一个需要右移的字符个数n,实现类似输入这样MakeString("abcdefghi",2),字符串右移后变成:hiabcdeg;
以下给出我当时的解法,希望各位看官有什么意见或者建议多多给我指点指点。
void MakeString(char *pStr,int n) { char buf_heart[20] = ""; char buf_back[20] = ""; int iCount = 0;//总字符个数 int leave = 0;//头部不动向后移动的个数 int i = 0; char *p = pStr; while(*p != '\0') { iCount++; p++; } if (n > iCount) { return;//超过字符串大小返回 } leave = iCount - n; for (i = 0;i < leave;i++)//存下原字符串被放到末尾的字符串 { buf_back[i] = pStr[i]; } for (i = 0;i < iCount;i++)//存下原字符串被放到头部的字符串 { buf_heart[i] = pStr[leave]; leave++; } strcpy(pStr,buf_heart); strcat(pStr,buf_back); } |