- 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语言在线测评答案第10章字符串(2013级亲测正确)选编
PAGE \* MERGEFORMAT 20
10.1 字符转换
描述 提取一个字符串中的所有数字字符(‘0’...‘9’)将其转换为一个整数输出。
输入 一个以回车符为结束标志的字符串(少于80个字符)。
输出 把字符串中的所有数字字符(‘0’...‘9’)转换为一个整数并输出。
#includestdio.h
#includestring.h
int main()
{
char s[80];
int i,k,n=0;
gets(s);
k=strlen(s);
for(i=0;ik;i++)
if(s[i]=0s[i]=9)
n=n*10+(s[i]-0);
printf(%d\n,n);
return 0;
}
10.2 合并字符串
输入两个已经按从小到大顺序排列好的字符串,编写一个合并两个字符串的函数,使合并后的字符串,仍然是从小到 大排列。
输入: 两个已经排好顺序(升序)的字符串
输出: 一个合并在一起的有序(升序)的字符串
要求: 设计一个效率尽量高的算法,对每个字符串只扫描一遍就可以了。如果采用先进行串连接,然后再进行排序的算法,则效率太低了。
#includestdio.h
#includestring.h
int main()
{
char a[100],b[100],t;
int k,i,j;
gets(a); gets(b);
strcat(a,b);
k=strlen(a);
/*冒泡法排序*/
for(i=1;ik;i++) /*不能用字符串数组最后一项\0和前面项比较,故i从1开始*/
for(j=0;jk-i;j++)
if(a[j]a[j+1])
{ t=a[j];
a[j]=a[j+1];
a[j+1]=t; }
puts(a);
return 0;
}
10.3 删除重复字符
背景: 输入一个长度不超过 100 的字符串,删除串中的重复字符。
输入: 输入要检查的字符串,长度不超过100个字符。例如:abacaeedabcdcd。
输出: 删除重复字符后的字符串。例如:abced。
#includestdio.h
#includestring.h
int main()
{
char a[100],b[100];
int k,i,j;
gets(a);
k=strlen(a);
for(i=0;ik;i++)
for(j=i+1;jk;j++)
if(a[j]==a[i]) a[j]=\0;
for(i=0;ik;i++)
if(a[i]!=\0)
printf(%c,a[i]);
printf(\n);
return 0;
}
10.4 删除字符串中指定字符
输入两个字符串 s1 和 s2 ,在 s1 中删除任何 s2 中有的字符。
输入: 两个字???串 s1 和 s2 输出: 删除后的字符串 s1
#includestdio.h
#includestring.h
int main()
{
char s1[20],s2[20];
int k1,k2,i,j;
gets(s1); gets(s2);
k1=strlen(s1); k2=strlen(s2);
for(j=0;jk2;j++)
for(i=0;ik1;i++)
if(s1[i]==s2[j]) s1[i]=\0;
j=0;
for(i=0;ik1;i++)
if(s1[i]!=\0)
{ s1[j]=s1[i]; j++; }
s1[j]=\0;
puts(s1);
return 0;
}
10.5 单词有多少
用空格或换行分开的字符串称为单词。输入多行字符串,直到遇到了单词 stop 时才停止。最后输出单词的数量。用于分割单词的空格或换行可能多于1个。
输入: 多个字符串 输出: 单词的数量
#includestdio.h
#includestring.h
int main()
{
char s[20];
int i,n=0;
for(i=0;;i++)
{ scanf(%s,s); /*scanf遇空格或换行则存入下一个s[20]*/
n++; /*不能gets(s),它
文档评论(0)