字符串循环右移

 

 

 

/*.编写一个函数,作用是把一个char 组成的字符串循环右移n个。比如原来是“abcdefghi”如果n=2,移位后应该是“hiabcdefg”

 函数头是这样的:void loop_move (char *str,  int n)

 */

#import <Foundation/Foundation.h>

void loop_move (char *str,  int n)

{

    char * s = str;                                                 //记录字符串首地址

    char  num = n % (int)strlen(str);       //如果移动位数大于字符串的字符数,计算出等效移 位数。

    

    char  * p = malloc(num*sizeof(char));//在堆空间开辟空间暂存移动的字符

    memcpy(p,str +strlen(str) - num , num*sizeof(char));//将需要移动的字符复制到堆空间

    while (*(str + num+1)) {

        str++;

    }                                                                                       //指针移动到最先需要又移的字符处

    

    while (str >= s) {                                                              //字符串右移

      *(str+num) =   *str;

        str--;

    }

memcpy(s,p,num*sizeof(char)); //完成字符串右移后将暂存在堆空间中的字符复制到字符串前端

    free(p);                                                //释放堆内存

}

int main(int argc, const char * argv[])

{

    char  str[] = "i love iphone and  ios";

    loop_move(str, 2);

    printf("%s",str);

    

    return 0;

}

 

posted @ 2013-09-28 17:04  月影空  阅读(877)  评论(0编辑  收藏  举报