本网站(662p.com)打包出售,且带程序代码数据,662p.com域名,程序内核采用TP框架开发,需要联系扣扣:2360248666 /wx:lianweikj
精品域名一口价出售:1y1m.com(350元) ,6b7b.com(400元) , 5k5j.com(380元) , yayj.com(1800元), jiongzhun.com(1000元) , niuzen.com(2800元) , zennei.com(5000元)
需要联系扣扣:2360248666 /wx:lianweikj
C语言字符串左旋的两种实现方法
chenguangming9 · 143浏览 · 发布于2023-02-06 +关注

汇编语言中有一种移位指令叫做循环左移(ROL),下面这篇文章主要给大家介绍了关于C语言字符串左旋的两种实现方法,文中通过实例代码介绍的非常详细,需要的朋友可以参考下


题目内容:

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

例如:

ABCD左旋一个字符得到BCDA。

ABCD左旋两个字符得到CDBA。

方法一:

所谓左旋,不就是将字符串第一个元素放到末尾嘛,所以我们可以将字符串第一个元素取出,将字符串其他元素全部向前挪动一位,这时字符串的最后一位刚好空出,我们再将首元素放在最后一位,完美完成了一次字符串左旋。

 代码实现如下

#include<stdio.h>
#include<string.h>
void string_revolve1(char* str, int k)
{
    //左旋一个字符
    int n = strlen(str);
    int i = 0;
    for (i = 0; i < k; i++)
    {
        char tmp = *str;
        int j = 0;
        //每个字符向前移动一位
        for (j = 0; j < n; j++)
        {
            *(str + j) = *(str + j + 1);
        }
        //第一个字符旋转到最后一位
        *(str + n - 1) = tmp;
    }
}
int main()
{
    char a[111];
    gets(a);
    int k = 0;
    scanf("%d", &k);
    string_revolve1(a, k);
    printf("%s",a);
    return 0;
}

方法2:三步翻转法

首先我们看一个字符串:   ABCDEF 假如我们要左旋k=2个字符 ,我们便有如下做法:

1. 先逆序字符k之前的字符,也就是逆序前两个字符

ABCDEF --- BACDEF

2.再逆序字符k之后的字符,也就是逆序后四个字符

BACDEF---BAEFDC

3.再逆序此字符串整体,便可以得到结果

BAEFDC---CDFEBA

是不是十分神奇?接下来我们根据此思路,写出代码

#include<stdio.h>
#include<string.h>
void reverse_ordef(char* left,char* right)
{
    while (left < right)
    {
        char tmp = *left;
        *left = *right;
        *right = tmp;
        left++;
        right--;
    }
}
void string_revolve2(char* str, int k)
{
    // a b c d e f
    int n = strlen(str);
    //将k之前的字符逆序
    reverse_ordef(str, str + k - 1);
    //将k之后的字符逆序
    reverse_ordef(str+k,str+n-1);
    //将字符串整体逆序
    reverse_ordef(str, str+n-1);
}
int main()
{
    int k = 0;
    char str[111];
    gets(str);
    scanf("%d", &k);
    string_revolve2(str, k);
    printf("%s", str);
    return 0;
}

补充:C语言--左旋字符串中的k个字符

看这么一个问题:

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

  • ABCD左旋一个字符得到BCDA

  • ABCD左旋两个字符得到CDAB

拿到问题后,我们首先应该理解题意。什么是左旋?根据例题可以看出是把k个字符经过左旋放到后面,下面给出两种方法来求解:方法一:暴力求解

#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <string.h>
 void left_move(char* str, int k)
{
    int j = 0;
    for(j=0; j<k; j++)
    {
        //旋转1个字符
        char tmp = *str;
        int len = strlen(str);
        int i = 0;
        for(i=0; i<len-1; i++)
        {
            *(str+i) = *(str+i+1);
        }
        *(str+len-1) = tmp;
    }
}
 int main()
{
    char arr[] = "abcdef";//cdefab
    left_move(arr, 8);
    printf("%s\n", arr);
    system("pause");
    return 0;
}

这种方法的优点是容易想到,实现起来比较容易。保利求解思想就是你给一个k我就给你左旋k个字符串,但也存在一些缺点,比如可能存在某些问题。下面我们来看另一个较优方法。

方法二

我们来先看代码:

#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <string.h>
 void reverse_str(char *left, char *right)
{
    assert(left != NULL);
    assert(right != NULL);
    while(left<right)
    {
        char tmp = *left;
        *left = *right;
        *right = tmp;
        left++;
        right--;
    }
}
 void left_move(char* str, int k)
{
    int len = 0;
    assert(str != NULL);
    len = strlen(str);
    reverse_str(str, str+k-1);
    reverse_str(str+k, str+len-1);
    reverse_str(str, str+len-1);
}
 int main()
{
    char arr[] = "abcdef";//cdefab
    left_move(arr, 8);
    printf("%s\n", arr);
    system("pause");
    return 0;
}

这个方法比较灵活,他根据abcdef先在k个字符左右先各自左旋得到字符串bafedc,再将整个字符串整体左旋得到所求字符串cdefab;这个方法比较灵性,它合理的将问题拆分,化成一个个来求解,所以这里比较推荐第二个方法。希望可以给大家带来帮助,一起学习进步。


c

相关推荐

PHP实现部分字符隐藏

沙雕mars · 1325浏览 · 2019-04-28 09:47:56
Java中ArrayList和LinkedList区别

kenrry1992 · 908浏览 · 2019-05-08 21:14:54
Tomcat 下载及安装配置

manongba · 970浏览 · 2019-05-13 21:03:56
JAVA变量介绍

manongba · 962浏览 · 2019-05-13 21:05:52
什么是SpringBoot

iamitnan · 1086浏览 · 2019-05-14 22:20:36
加载中

0评论

评论
分类专栏
小鸟云服务器
扫码进入手机网页