1.实现一个函数,可以左旋字符串中的k个字符。 ABCD左旋一个字符得到BCDA ABCD左旋两个字符得到CDAB // void left_move(char *str, int k) {}

第一种方法

#define	_CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
void left_move(char* str, int k)
{  
	int i = 0;
	for (i = 0; i < k; i++)

	{
		char tmp = *str;
		int j = 0;
		while (*(str+j+1))
		{
			*(str + j) = *(str + j + 1);
			j++;
		}
		*(str + j) = tmp;
	}
}
int main()
{
	char str[] = "ABCD";
	int a = 0;
	printf("请输入左旋的字符个数\n");
	scanf("%d", &a);
	printf("%s\n", str);
	left_move(str,a);
	printf("%s\n", str);
	system("pause");
	return 0;
}

第二种方法

  #define	_CRT_SECURE_NO_WARNINGS
    #include<stdio.h>
    #include<stdlib.h>
    #include<string.h>
    void left_move(char* str, int k)
    {
    	int i = 0;
    	char tmp;
    	for (i = 0; i < (k % 4); i++)
    	{
    		tmp = *(str+i);
    		*(str + i) = *(str + 4 + i);
    		*(str + 4 + i) = tmp;
    	}
    }
    int main()
    {
    	char str[] = "ABCD     ";
    	int a = 0;
    	printf("请输入左旋的字符个数\n");
    	scanf("%d", &a);
    	printf("%s\n", str);
    	left_move(str, a);
    	printf("%s\n", str+(a%4));
    	system("pause");
    	return 0;
    }

猜你喜欢

转载自blog.csdn.net/belongHWL/article/details/91489195
今日推荐