字符串左旋

第一次尝试
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>

void LeftString(char* str,int size,int num) {
    int i = 0;
    for (i = 0; i < num; i++) {
        str[size+i] = str[i];
        str[size + 1 + i] = '\0';
    }
    for (int j = i; str[j] != '\0'; j++) {
        printf("%c", str[j]);
    }printf("\n");
}

int Size(char* str) {
    int ret = 0;
    for (int i = 0; str[i] != '\0'; i++) {
        ret++;
    }
    return ret;
}

int main() {
    //可以将第一个取出,然后将后面的字符前移,然后把取出的字符放到末位,以此类推;但是较麻烦,
    //所以,我采用字符串空间只要足够大,前面交换到后面的字符就不会越界,也可以实现目的
    char str[20] = "abcde";
    int size = Size(str);
    //printf("%d", size);
    printf("%s\n", str);
    printf("输入要左旋转多少字符:");
    int num = 0;
    scanf("%d", &num);
    LeftString(str, size, num);

    //验证如果将前面的字符直接放到‘\0’的位置上
    //并且不在后面附上‘\0’那么后面会出现乱码
    /*str[9] = 'j';
    printf("%s", str);*/
    return 0;
}

//或者还有一个方法:
//先将要左旋的前三个家伙逆序(CBADEFG),然后将后半段也逆序(CBAGFED),最后整体逆序(DEFGABC)即可。
//这样只需要做数值交换即可,可以写一个函数帮我们完成局部逆序,代码如下:
//void reverse_part(char* str, int start, int end) //将字符串从start到end这一段逆序
//{
//    int i, j;
//    char tmp;
//
//    for (i = start, j = end; i < j; i++, j--)
//    {
//        tmp = str[i];
//        str[i] = str[j];
//        str[j] = tmp;
//    }
//}
//
//void leftRound(char* src, int time)
//{
//    int len = strlen(src);
//    int pos = time % len;
//    reverse_part(src, 0, pos - 1); //逆序前段
//    reverse_part(src, pos, len - 1); //逆序后段
//    reverse_part(src, 0, len - 1); //整体逆序
//}

此代码思路很多,解决方法较多,具体想法见代码中的注释。


博客园发表于 2020-11-13 13:21

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值