欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言字符串左旋的兩種實(shí)現(xiàn)方法

 更新時(shí)間:2023年02月06日 11:45:44   作者:宜昌精神病院郭院長  
匯編語言中有一種移位指令叫做循環(huán)左移(ROL),下面這篇文章主要給大家介紹了關(guān)于C語言字符串左旋的兩種實(shí)現(xiàn)方法,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

題目內(nèi)容:

實(shí)現(xiàn)一個(gè)函數(shù),可以左旋字符串中的k個(gè)字符。

例如:

ABCD左旋一個(gè)字符得到BCDA。

ABCD左旋兩個(gè)字符得到CDBA。

方法一:

所謂左旋,不就是將字符串第一個(gè)元素放到末尾嘛,所以我們可以將字符串第一個(gè)元素取出,將字符串其他元素全部向前挪動(dòng)一位,這時(shí)字符串的最后一位剛好空出,我們再將首元素放在最后一位,完美完成了一次字符串左旋。

 代碼實(shí)現(xiàn)如下

#include<stdio.h>
#include<string.h>
void string_revolve1(char* str, int k)
{
	//左旋一個(gè)字符
	int n = strlen(str);
	int i = 0;
	for (i = 0; i < k; i++)
	{
		char tmp = *str;
		int j = 0;
		//每個(gè)字符向前移動(dòng)一位
		for (j = 0; j < n; j++)
		{
			*(str + j) = *(str + j + 1);
		}
		//第一個(gè)字符旋轉(zhuǎn)到最后一位
		*(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:三步翻轉(zhuǎn)法

首先我們看一個(gè)字符串:   ABCDEF 假如我們要左旋k=2個(gè)字符 ,我們便有如下做法:

1. 先逆序字符k之前的字符,也就是逆序前兩個(gè)字符

ABCDEF --- BACDEF

2.再逆序字符k之后的字符,也就是逆序后四個(gè)字符

BACDEF---BAEFDC

3.再逆序此字符串整體,便可以得到結(jié)果

BAEFDC---CDFEBA

是不是十分神奇?接下來我們根據(jù)此思路,寫出代碼

#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;
}

補(bǔ)充:C語言--左旋字符串中的k個(gè)字符

看這么一個(gè)問題:

1.實(shí)現(xiàn)一個(gè)函數(shù),可以左旋字符串中的k個(gè)字符。

  • ABCD左旋一個(gè)字符得到BCDA
  • ABCD左旋兩個(gè)字符得到CDAB

拿到問題后,我們首先應(yīng)該理解題意。什么是左旋?根據(jù)例題可以看出是把k個(gè)字符經(jīng)過左旋放到后面,下面給出兩種方法來求解:方法一:暴力求解

#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++)
?? ?{
?? ??? ?//旋轉(zhuǎn)1個(gè)字符
?? ??? ?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;
}

這種方法的優(yōu)點(diǎn)是容易想到,實(shí)現(xiàn)起來比較容易。保利求解思想就是你給一個(gè)k我就給你左旋k個(gè)字符串,但也存在一些缺點(diǎn),比如可能存在某些問題。下面我們來看另一個(gè)較優(yōu)方法。

方法二

我們來先看代碼:

#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;
}

這個(gè)方法比較靈活,他根據(jù)abcdef先在k個(gè)字符左右先各自左旋得到字符串bafedc,再將整個(gè)字符串整體左旋得到所求字符串cdefab;這個(gè)方法比較靈性,它合理的將問題拆分,化成一個(gè)個(gè)來求解,所以這里比較推薦第二個(gè)方法。希望可以給大家?guī)韼椭?,一起學(xué)習(xí)進(jìn)步。

總結(jié)

到此這篇關(guān)于C語言字符串左旋的兩種實(shí)現(xiàn)方法的文章就介紹到這了,更多相關(guān)C語言字符串左旋內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++大整數(shù)加法解題思路及參考代碼

    C++大整數(shù)加法解題思路及參考代碼

    大整數(shù)加法的思路是用兩個(gè)數(shù)組儲(chǔ)存兩個(gè)整數(shù)的每一位然后分別相加,下面這篇文章主要給大家介紹了關(guān)于C++大整數(shù)加法解題思路及參考代碼的相關(guān)資料,需要的朋友可以參考下
    2024-03-03
  • C++之BOOST字符串查找示例

    C++之BOOST字符串查找示例

    這篇文章主要介紹了C++之BOOST字符串查找的方法,實(shí)例演示了boost針對字符串的查找、判定及替換等操作,具有一定的實(shí)用價(jià)值,需要的朋友可以參考下
    2014-10-10
  • C++實(shí)現(xiàn)LeetCode(40.組合之和之二)

    C++實(shí)現(xiàn)LeetCode(40.組合之和之二)

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(40.組合之和之二),本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C++命名空間?缺省參數(shù)?const總結(jié)?引用總結(jié)?內(nèi)聯(lián)函數(shù)?auto關(guān)鍵字詳解

    C++命名空間?缺省參數(shù)?const總結(jié)?引用總結(jié)?內(nèi)聯(lián)函數(shù)?auto關(guān)鍵字詳解

    這篇文章主要介紹了C++命名空間?缺省參數(shù)?const總結(jié)?引用總結(jié)?內(nèi)聯(lián)函數(shù)?auto關(guān)鍵字詳解的相關(guān)資料,需要的朋友可以參考下
    2023-01-01
  • C++針對bmp格式解析實(shí)例

    C++針對bmp格式解析實(shí)例

    這篇文章主要介紹了C++針對bmp格式解析實(shí)例,設(shè)計(jì)CWnd框架的使用及位圖的操作,需要的朋友可以參考下
    2014-10-10
  • c語言實(shí)現(xiàn)簡單的易語言

    c語言實(shí)現(xiàn)簡單的易語言

    在本篇內(nèi)容里小編給大家整理了一篇關(guān)于c語言實(shí)現(xiàn)一個(gè)簡單的易語言的相關(guān)知識(shí)點(diǎn),需要的朋友們參考下。
    2018-12-12
  • C語言學(xué)生學(xué)籍管理系統(tǒng)課程設(shè)計(jì)

    C語言學(xué)生學(xué)籍管理系統(tǒng)課程設(shè)計(jì)

    這篇文章主要介紹了C語言學(xué)生學(xué)籍管理系統(tǒng)課程設(shè)計(jì),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • C語言設(shè)計(jì)前中后隊(duì)列實(shí)例代碼

    C語言設(shè)計(jì)前中后隊(duì)列實(shí)例代碼

    隊(duì)列最主要的作用就是用來管理數(shù)據(jù)流的,防止數(shù)據(jù)因?yàn)閭鬏旑l率過快得不到及時(shí)處理而丟失,下面這篇文章主要給大家介紹了關(guān)于C語言設(shè)計(jì)前中后隊(duì)列的相關(guān)資料,需要的朋友可以參考下
    2021-12-12
  • C++實(shí)現(xiàn)各種排序算法類匯總

    C++實(shí)現(xiàn)各種排序算法類匯總

    這篇文章主要介紹了C++實(shí)現(xiàn)各種排序算法類,需要的朋友可以參考下
    2014-07-07
  • C++中register關(guān)鍵字舉例詳解

    C++中register關(guān)鍵字舉例詳解

    register用來聲明變量,然后聲明出來的變量是直接放在cpu的寄存器當(dāng)中,而非就是通過內(nèi)存尋址訪問,這樣效率更高,下面這篇文章主要給大家介紹了關(guān)于C++中register關(guān)鍵字的相關(guān)資料,需要的朋友可以參考下
    2023-03-03

最新評(píng)論