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

邯郸网络营销和网络推广湖北网站seo

邯郸网络营销和网络推广,湖北网站seo,最近免费高清版电影在线观看,app和网站的区别是什么题目:实现一个函数,可以实现字符串的左旋 例如:ABCD左旋一个字符就是BCDA;ABCD左旋两个字符就是CDAB; 1、解题思路: 1.确定目标旋转k个字符,我们要获取字符串的长度 len,目的是根…

题目:实现一个函数,可以实现字符串的左旋

例如:ABCD左旋一个字符就是BCDA;ABCD左旋两个字符就是CDAB;

1、解题思路:

1.确定目标旋转k个字符,我们要获取字符串的长度 len,目的是根据长度来处理 k 可能超出字符串长度的情况;

2.创建一个函数 left 来实现字符串左旋;

3.对k进行取模运算:k%=len,该表达式目的是计算实际旋转次数。假设字符串长度是 5,而要左旋 7 个字符,实际上相当于左旋 7 % 5 = 2 个字符。

4.创建一个临时数组 temp 来存放要左旋的 k 个字符,防止后续移动字符串时数据丢失。

5.使用 strncpy 将字符串前 k 个字符复制到 temp 中,使用 memmove 函数移动字符串,把从第 k 个字符开始的部分向前移动 k 个位置。(等会简单介绍一下函数的使用)

6.使用 strncat 函数将保存在 temp 中的前 k 个字符拼接到移动后的字符串后面,完成左旋操作。

2、知识补充:

注:这里就简单介绍一下用法,能让大家读懂我后面写的代码,后面会专门出一篇文章来介绍这些函数。以下介绍的函数使用都需要加上头文件<string.h>

1、strncpy

strncpy是字符串复制函数,作用是将指定数量的字符从源字符串复制到目标字符串。

函数原型:char *strncpy(char *dest, const char *src, size_t n)

  • dest:目标字符串。
  • src :源字符串。
  • n :要复制的最大字符数。

使用:

#include <stdio.h>
#include <string.h>
int main() {char dest[10];char src[] = "Hello";strncpy(dest, src, 2);  // 复制 src 的前 2 个字符到 destdest[2] = '\0';  // 手动添加字符串结束符printf("%s\n", dest);  // 输出 "He"return 0;
}

2.memmove

memmove是内存操作函数,作用是将 n个字节的数据从 src 所指向的内存区域复制到 dest 所指向的内存区域,可以处理源内存区域和目标内存区域重叠的情况,保证正确地复制数据。

函数原型:void *memmove(void *dest, const void *src, size_t n)

  • dest:指向目标内存区域的指针,数据将被移动到这里。
  • src:指向源内存区域的指针,数据将从此处移动。
  • n :要移动的字节数。

使用:

#include <stdio.h>
#include <string.h>int main() {char str[] = "HelloWorld";memmove(str + 5, str, 5);printf("%s\n", str); return 0;
}

3.strncat 

 strncat是字符拼接函数,作用是将源字符串 scr 中的最多 n 个字符拼接到目标字符串 dest 的末尾,并在拼接后的字符串末尾自动添加字符串结束符 '\0'

函数原型:char *strncat(char *dest, const char *src, size_t n)(同上)

使用:

#include <stdio.h>
#include <string.h>int main() {char dest[20] = "Hello, ";char src[] = "World!";strncat(dest, src, 5);  // 拼接 src 的前 5 个字符printf("%s\n", dest);  // 输出 "Hello, World"return 0;
}

3、代码展示及解析:

#include <stdio.h>
#include <string.h>
void left(char* str, int k)//完成字符左旋操作
{int len = strlen(str);k %= len;//实际左旋次数char temp[2];//这里使用2表示是因为在vs2022上表达式必须含有常量值strncpy(temp, str, k);//复制要左旋的k个字符到临时数组temp中memmove(str, str + k, len - k);//移动字符串str[len - k] = '\0';//确保完整性strncat(str, temp, k);//将存储在 temp 中的前 k 个字符拼接到移动后的字符串后面
}
int main()
{char str[] = "abcd";int k = 2;//左旋个数为2printf("左旋前:%s\n", str);left(str, k);//实现左旋操作的函数调用printf("左旋后:%s\n", str);return 0;
}

char temp[2]这是由于vs2022不支持变长数组才这样写的代码,如果你所使用的编译器支持边长数组,可以改进一下代码

代码改进:

#include <stdio.h>
#include <string.h>
void left(char* str, int k)
{int len = strlen(str);k %= len;char temp[k];//变长数组strncpy(temp, str, k);memmove(str, str + k, len - k);str[len - k] = '\0';strncat(str, temp, k);
}
int main()
{char str[] = "abcd";int k = 2;printf("左旋前:%s\n", str);left(str, k);printf("左旋后:%s\n", str);return 0;
}

 

如果在支持变长数组,这样写代码会更加的方便,你只需要修改所输入k的值就可以实现左旋不同个字符,例如:输入k=1,左旋一个字符;输入k=2,左旋两个字符。

4、不使用这些库函数来实现字符串左旋

代码及注释:(这个是结合老师的讲解所写的)

#include <stdio.h>
// 左旋字符串函数
void left(char* str, int k)
{int len = 0;  // 存储字符串长度char* p = str;  //遍历字符串计算长度while (*p) // 计算字符串长度{len++;p++;}k %= len;  // 实际左旋次数for (int i = 0; i < k; i++)  // 进行左旋操作{char temp = *str;  // 保存字符串要左旋的k个字符  for (int j = 0; j < len - 1; j++)  // 将字符串从第二个字符开始依次向前移动一位{*(str + j) = *(str + j + 1);}*(str + len - 1) = temp;  // 将保存的k个字符放到字符串尾部}
}
int main() 
{char str[] = "ABCD";int k = 2;printf("左旋前: %s\n", str);left(str, k);printf("左旋后: %s\n", str);return 0;
}

http://www.wangmingla.cn/news/67994.html

相关文章:

  • 杭州网络推广公司那家好优化网站服务
  • 去国外做外卖网站好营销策划方案1000例
  • 网站关键词排名怎么做广州番禺发布
  • 企业营销型网站分析网络新闻发布平台发稿
  • 网站举报多久有结果app推广平台
  • 武邑网站建设代理怎么注册电商平台
  • wordpress数据库改域名seo做的好的网站
  • 网站建设的认识阜阳seo
  • 四库一平台查询系统seo的概念是什么
  • 在线做漫画的网站站长平台工具
  • 网站响应是什么问题吗百度指数有三个功能模块
  • 网站 如何做 中英文切换百度广告费
  • 海口房产网站建设长春网站推广排名
  • 动态网站建设外贸网站推广方法之一
  • wordpress 插件结构谷歌seo培训
  • wordpress 站内信 群发磁力猫最好磁力搜索引擎
  • 青岛做网站优化的公司最新疫情最新情况
  • 西安学网站开发哪边好谷歌推广一年多少钱
  • 英文在线购物网站建设网络广告的形式有哪些?
  • 用java做网站的流程武汉seo关键字推广
  • 怎么做网站排名会更好丹东网站seo
  • 临沂做网站推广的公司有搜索引擎seo是什么意思
  • 用模板做网站的方法浏览器直接进入网站的注意事项
  • 个人个案网站 类型搜索引擎有哪些类型
  • wordpress链接选项不见了seo公司哪家好
  • 200元网站建设太原搜索引擎优化
  • 软件开发网站开发行业数据统计网站
  • 营销型网站制作msgg北京seo包年
  • 用flash做网站教程青岛网站建设方案服务
  • 网站建设注册什么公司站长收录平台