- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
c 语言 输入一个字符串 循环右移 n个 得到一个新的字符串
2011-5-15 22:25
提问者:匿名|浏览次数:880次
老师布置了一道题
编写一个函数,作用是把一个 char 组成的字符串循环右移 n 个。比如原来是 “ hellow“
如果 n=2 ,移位后应该是 “owhell”
我偷了小懒用下面的方法实现了 但是当 n =4 程序的 h就输入不出来了 那为高手帮忙解释下 谢谢了
#include stdio.h
#include string.h
void LoopMove(char *s,int n)
{
char *s1;
int t1=strlen(s);
int t =strlen(s)-n;
char s2[] ={0};
s1=s+t;
printf(%d\n,t);
strcpy(s2,s1);
strncpy(s2+n,s,t);
strcpy(s,s2);
}
int main()
{
int n=4;
char s[] =hello;
char *p= NULL;
LoopMove(s,n);
printf(%s\n,s);
}
谢谢!
我来帮他解答
2011-5-15 22:50
满意回答
有问题找代码:char s2[] ={0};
这里相当于s2是1个字符的数组。当对它做类似strcpy(s2,s1);的操作时,只要s1的长度(这里是n)大于1,就会出现数组访问越界。对于像数组访问越界这种错误会引发的结果是不确定性,有可能程序正常运行,也可能会崩溃,取决于越界之后访问到的内存地址的相关属性。
将s2改一个动态数组,程序就能正常运行。代码如下:
#include stdio.h
#include stdlib.h
#include string.h
void LoopMove(char *s,int n)
{
char *s1;
int t1=strlen(s);
int t =strlen(s)-n;
char* s2 = (char*)malloc((t1 + 1) * sizeof(char)); //分配t1+1个字符的空间,之所以加1是因为C中字符串默认以\0结尾,strlen的结果是没包含这个\0的。
memset(s2, 0, t1 + 1); // 清空s2的内容
s1=s+t;
printf(%d\n,t);
strcpy(s2,s1);
strncpy(s2+n,s,t);
strcpy(s,s2);
free(s2); // 释放资源
}
int main()
{
int n=4;
char s[] =hello;
char *p= NULL;
LoopMove(s,n);
printf(%s\n,s);
}
在一次面试题中曾遇到过一个题目是使字符串循环移动指定的位数!下面和大家讨论几点有关的算法!#includestdio.h#includestring.h#includestdlib.hvoid strRightMove(char**a,int bit){int len= strlen(*a);if(bit%= len){char *str=(char*)malloc(len+ 1);strncpy(str,(*a+ len- bit), bit);str[bit]= \0;strncat(str,*a,len-bit);*a= str;}}int main(){char *a= 1234567890;strRightMove(a,5);puts(a);return 0;}当然还有其他方法#includestring.h#includestdlib.hvoid right_shift(char *dest,int shift){char *temp= NULL;int len= 0;int actual= 0;int i= 0;int sub= 0;if(shift 0){printf(Error number\n);return;}if(dest== NULL|| *dest== \0){printf(Error:Null string\n);}len= strlen(dest);actual= shift% len;if(actual== 0)return;temp= (c
您可能关注的文档
最近下载
- 美术与音乐的互通关系_美术论文.doc VIP
- 初中八年级音乐上册《春江花月夜》PPT课件.ppt VIP
- 2025河南郑州高新区招聘社区工作人员100人笔试备考试题及答案解析.docx VIP
- 西南15G701-3 混凝土结构轻质填充墙构造图集 第三分册 烧结空心砖填充墙.pdf VIP
- 医学基础考试试题.docx VIP
- 关于领导干部任职试用期现实表现情况报告.docx VIP
- 2025河南郑州高新区招聘社区工作人员100人笔试备考题库及答案解析.docx VIP
- 【廉政党课】全面从严治党-抓好党风廉政建设.pptx VIP
- 2022广东省中学生天文知识竞赛低年组试题答案.pdf VIP
- 环保校本校本课程.doc VIP
文档评论(0)