实现一个函数,可以左旋字符串中的k个字符

版权声明:版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/kevin980123 https://blog.csdn.net/kevin980123/article/details/79981563

实现一个函数,可以左旋字符串中的k个字符

如:
ABCD左旋一个字符得到BCDA
ABCD左旋两个字符得到CDAB


程序代码如下:



#include <stdio.h>

void change(char *p, char *q)
{
    while (p < q)
    {
        char tmp = *p;
        *p = *q;
        *q = tmp;
        p++;
        q--;
    }
}

int length(char c[])
{
    int i = 0;
    for (i = 0; c[i] != '\0'; i++)
    {
        ;
    }
    return i;
}

void TurnLeft(char c[], int n)
{
    change(c, c+n-1);
    change(c+n, c+length(c)-1);
    change(c, c+length(c)-1);
}

int main()
{
    char c[] = "abcdef";
    int k = 0;
    int i = 0;
    printf("c = %s\n", c);
    printf("请输入要左旋的字符个数:\n");
    scanf("%d", &k);
    TurnLeft(c, k);
    printf("c = %s\n", c);
    return 0;
}

程序运行结果如下:


这里写图片描述

阅读更多

没有更多推荐了,返回首页