当前位置: 首页 > news >正文

怎么样建立个人网站少林寺网站谁做的

怎么样建立个人网站,少林寺网站谁做的,付网站建设费分录,黄山市建设工程造价管理站网站C语言–字符串旋转笔试题 文章目录 C语言--字符串旋转笔试题一、字符串左旋1.1 思路11.2 思路1代码1.3 思路21.4 思路2代码 二、字符串旋转结果判断2.1 思路12.2 思路2 一、字符串左旋 实现一个函数,可以左旋字符串中的k个字符。 例如: ABCD左旋一个字…

C语言–字符串旋转笔试题

文章目录

  • C语言--字符串旋转笔试题
  • 一、字符串左旋
    • 1.1 思路1
    • 1.2 思路1代码
    • 1.3 思路2
    • 1.4 思路2代码
  • 二、字符串旋转结果判断
    • 2.1 思路1
    • 2.2 思路2


一、字符串左旋

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

例如:

ABCD左旋一个字符得到BCDA

ABCD左旋两个字符得到CDAB

1.1 思路1

先把第一个元素取出来暂时存放在变量中,后面的整体移动到前面,然后把第一个变量存放在最后的位置,循环往复。
在这里插入图片描述

1.2 思路1代码

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include<string.h>
void left_move(char arr[], int k)
{int i = 0;int len = strlen(arr);for (i = 0; i < k; i++){//先保存首元素char tmp = arr[0];//将后面的值放到前面int j = 0;for (j = 0; j < len - 1; j++){arr[j] = arr[j + 1];}//将首元素放到最后arr[len - 1] = tmp;}
}
int main()
{char arr[] = "abcdefg";int k = 2;left_move(arr,k);printf("%s", arr);return 0;
}

1.3 思路2

逆序法:
ABCD
例如我要左旋2个字符,首先先将AB逆序,变成BA,然后再将CD逆序,变成DC,此时就是BADC,然后将整体逆序,变成CDBA
在这里插入图片描述

1.4 思路2代码

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include<string.h>
#include<assert.h>
//逆序函数
void reverse(char* left, char* right)
{assert(left);assert(right);while (left < right){char tmp = *left;*left = *right;*right = tmp;left++;right--;}}
void left_move(char arr[], int k)
{int i = 0;int len = strlen(arr);//逆序左边reverse(arr, arr + k - 1);//逆序右边reverse(arr + k, arr + len - 1);//逆序整体reverse(arr, arr + len - 1);
}
int main()
{char arr[] = "abcdefg";int k = 2;left_move(arr,k);printf("%s", arr);return 0;
}

二、字符串旋转结果判断

写一个函数,判断一个字符串是否为另外一个字符串旋转之后的字符串。

例如:给定s1 =AABCD和s2 = BCDAA,返回1

给定s1=abcd和s2=ACBD,返回0.

AABCD左旋一个字符得到ABCDA

AABCD左旋两个字符得到BCDAA

AABCD右旋一个字符得到DAABC

2.1 思路1

依赖于上面写过的旋转函数,将字符串旋转之后看两个字符串是否相同来判断

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<string.h>
#include<assert.h>void reverse(char* left, char* right)
{assert(left);assert(right);while (left < right){char tmp = *left;*left = *right;*right = tmp;left++;right--;}}
void left_move(char arr[], int k)
{int i = 0;int len = strlen(arr);//逆序左边reverse(arr, arr + k - 1);//逆序右边reverse(arr + k, arr + len - 1);//逆序整体reverse(arr, arr + len - 1);
}
int is_left_move(char arr1[], char arr2[])
{int len1 = strlen(arr1);int len2 = strlen(arr2);if (len1 != len2)//如果两个字符串长度不相同,一定不是旋转得来的{return 0;}int i = 0;for (i = 0; i < len1; i++){left_move(arr1, 1);//每次旋转一个,然后判断是否相等if (strcmp(arr1, arr2) == 0)//如果出现小写字母,在这里就会发现{return 1;}}return 0;
}
int main()
{char arr1[] = "AABCD";char arr2[] = "BCDAA";int ret = is_left_move(arr1, arr2);if (ret == 1){printf("YES\n");}else{printf("NO\n");}return 0;}

2.2 思路2

AABCD 如果在后面再加上一组 AABCD 得出 AABCDAABCD那么就会得到AABCD所有旋转之后的结果,在和另一个字符串比较的时候,只需要判断其是不是AABCDAABCD的字串就可以了,前提还是这两个字符串长度相等的情况下

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<string.h>int is_left_move(char arr1[], char arr2[])
{int len1 = strlen(arr1);int len2 = strlen(arr2);if (len1 != len2)//如果两个字符串长度不相同,一定不是旋转得来的{return 0;}strncat(arr1, arr1, len1);//字符串追加函数,len1表示追加的个数if (strstr(arr1, arr2) != NULL)//strstr是在arr1字符串中查找arr2是否存在//如果存在则返回arr2在arr1中第一次出现的地址//如果不存在则返回NULL{return 1;}else{return 0;}}
int main()
{char arr1[20] = "AABCD";char arr2[] = "BCDAA";int ret = is_left_move(arr1, arr2);if (ret == 1){printf("YES\n");}else{printf("NO\n");}return 0;}
http://www.yayakq.cn/news/890560/

相关文章:

  • 设计网站推荐按钮的作用岳阳建设网站哪家好
  • 响应式网站 做搜索推广缺点网站备案资料表
  • 常州市城乡建设局网站线上线下推广方案
  • 建设网站都需要准备什么网站与微信结合
  • 网站建设中怎么设置默认页织梦做分销网站
  • 如何建设一个自己的网站一般做网站用什么软件
  • 柳州网站建设公司哪家好网络推广方法与技巧
  • 青海省公路建设市场信用信息服务网站金蝶财务软件官网报价
  • 工作室网站建设要多大内存网站可以做匿名聊天吗
  • 网站项目策划大纲买外链
  • 茂名东莞网站建设广告投放基础知识
  • 中英文网站asp怎么做红酒商城网站建设
  • 贴吧网站怎么做开发一个游戏大约要多少钱
  • 男女生做爰视频网站wordpress域名邮箱设置
  • 深圳企业品牌网站设计师门户网站程序
  • 陕西开龄建设网站智能建站工具
  • 不用登录的小游戏网站广州注册公司地址
  • 黄冈网站设计推广哪家好我爱搜罗 wordpress
  • 南京企业网站建设微信公众号推广方法有哪些
  • 电子商务网站建设应用技术彩票网站制作
  • 做微商网站设计做网站文字居中代码
  • 辣条类网站建设规划书成都做网站设
  • 做网站 套用模板之后用什么改哪些网站是做婴童辅食招商的
  • 金沙洲网站建设工作室同城可以做别人一样的门户网站吗
  • 网站开发html php个人简历封面模板免费
  • 在线编程的网站做网站应该用什么配置的手提电脑
  • 万网阿里云域名查询淘宝seo是什么
  • 自媒体seo优化沈阳企业网站seo公司
  • 免费网站建设ppt模板WordPress获取主题慢
  • 海南平台网站建设平台免费广告推广