海北高端网站建设,域名注册网站查询工具,网站域名和邮箱域名解析,海南做公司网站各位CSDN的uu们你们好呀#xff0c;今天#xff0c;小雅兰的内容依旧是复习之前的知识点#xff0c;那么#xff0c;就是做一道小小的题目啦#xff0c;下面#xff0c;让我们进入C语言的世界吧 实现一个函数#xff0c;可以左旋字符串中的k个字符。 例如#xff1a; A… 各位CSDN的uu们你们好呀今天小雅兰的内容依旧是复习之前的知识点那么就是做一道小小的题目啦下面让我们进入C语言的世界吧 实现一个函数可以左旋字符串中的k个字符。 例如 ABCD左旋一个字符得到BCDA ABCD左旋两个字符得到CDAB 首先给定一个字符串 如果是左旋一个字符那么可以这样来做把a拿出来放在自己定义的一个变量中再把b移到原来a的位置以此类推把c移到原先b的位置把d移到原先c的位置把e移到原先d的位置把f移到原先e的位置最后把a放到原先f的位置这样就成功左旋一个字符啦 好啦基本思路就是这个样子然后我们来写代码
#define _CRT_SECURE_NO_WARNINGS 1
#includestdio.h
#includestring.h
void left_move(char arr[], int k)
{int i 0;int len strlen(arr);k k % len;for (i 0; i k; i){//左旋一个字符//1char tmp arr[0];//2int j 0;for (j 0; j len - 1; j){arr[j] arr[j 1];}//3arr[len - 1] tmp;}
}
int main()
{char arr[20] abcdef;int k 0;scanf(%d, k);left_move(arr, k);printf(%s\n, arr);return 0;
} 另一种方法——三步翻转法 然后肯定需要用到字符串逆序的函数字符串逆序就是把b和c交换顺序a和d交换顺序f和e交换顺序
#includestdio.h
#includestring.h
#includeassert.h
void reverse(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 arr[], int k)
{int len strlen(arr);k k % len;reverse(arr, arr k - 1);//左reverse(arr k, arr len - 1);//右reverse(arr, arr len - 1);//整体
}
int main()
{char arr[20] abcdef;int k 0;scanf(%d, k);left_move(arr, k);printf(%s\n, arr);return 0;
} 写一个函数判断一个字符串是否为另外一个字符串旋转之后的字符串。 例如 给定s1 AABCD和s2 BCDAA返回1 给定s1abcd和s2ACBD返回0. AABCD左旋一个字符得到ABCDA AABCD左旋两个字符得到BCDAA AABCD右旋一个字符得到DAABC 和上面的题目非常相似
#includestdio.h
#includestring.h
int is_left_move(char arr1[], char arr2[])
{int i 0;int len strlen(arr1);for (i 0; i len; i){//左旋一个字符//1char tmp arr1[0];//2int j 0;for (j 0; j len - 1; j){arr1[j] arr1[j 1];}//3arr1[len - 1] tmp;if (strcmp(arr1, arr2) 0){return 1;}}return 0;
}
int main()
{char arr1[] abcdef;char arr2[] cdefab;int ret is_left_move(arr1, arr2);if (ret 1){printf(yes\n);}else{printf(no\n);}return 0;
} #includestdio.h
#includestring.h
int is_left_move(char arr1[], char arr2[])
{int len1 strlen(arr1);int len2 strlen(arr2);if (len1 ! len2){return 0;}strncat(arr1, arr2, len1);if (strstr(arr1, arr2)){return 1;}else{return 0;}
}
int main()
{char arr1[] abcdef;char arr2[] cdefab;int ret is_left_move(arr1, arr2);if (ret 1){printf(yes\n);}else{printf(no\n);}return 0;
} 这个代码中运行了很多字符串函数正好小雅兰之前写过这样的知识点
字符函数和字符串函数上——“C”_认真学习的小雅兰.的博客-CSDN博客
字符函数和字符串函数下——“C”_认真学习的小雅兰.的博客-CSDN博客 好啦小雅兰今天的内容就到这里啦继续加油