C语言二级日记------循环左移的算法

作为准备C语言二级的小白,积累一些算法有助于巩固C语言的基础,今天做到一题数组元素循环左移(右移)的算法,感觉对自己提高有一些帮助,也方便以后的复习,特此记录下来。

采用双层循环嵌套
内循环第二个字符开始每个字符前移一位
外层大循环控制左移(右移)次数

/*法1*/
void fun (char  *w,int  m)
{
  int i,j;
  int temp;
  for(i=1;i<=m;i++){
  temp=w[0];
  for(j=1;j!='/0';j++)//这里j!='/0'编译存在地址冲突,暂时还不明白
  w[j-1]=w[j];
  w[j-1]=temp;
  }
}
/*法2*/
void fun (char  *w,int  m)
{
    int len=strlen(w);
    int i;
    int j;
    for(j=0;j<m;j++)
    {
    char temp=w[0];
    for(i=1;i<len;i++)
        w[i-1]=w[i];
    w[len-1]=temp;
    }
}

还有一些别的方法,有待探索。

猜你喜欢

转载自blog.csdn.net/hua15617159775/article/details/81389940