实验六 参考答案
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
实验六参考答案(参考答案)
(1) 设计程序sy6-1.c,输入一个字符串,将其中的大写字母都改为对应的小写字母,其他字符不变。例如,若输入"Ab,cD",则输出"ab,cd"。
算法分析:
使用for循环遍历字符串,在遍历的过程中,如果该元素是大写字母时,能过str[i]=str[i]+32把大写字母置换成相应小写字母
参考答案:
#include
#include
void main()
{
char str[100];
int i;
printf("请输入一个字符串:");
gets(str);
for(i=0;str[i]!='\0';i++)
if(str[i]>='A'&&str[i]<='Z') str[i]=str[i]+32;
printf("输出转换后的字符串:");
puts(str);
}
运行结果:
(2) 设计程序sy6-2.c,输入一个字符串,删除其中所有的小写字母'c'。例如,若输入字符串"ac abc bcdef",则应输出字符串" a ab bdef"
算法分析:
在原字符数组中删除指定字符时,当遍历的字符不等于要删除的字符时,在原数组中赋值。注意在赋值的时候,元素下标不同步,所以用j做为删除后的下标,并且是赋一个值,其下标自动加1,所以最后j的值为数组的长度,另外为了保证字符数组能正确输出,所以在最后要人为加一个\0
参考答案:
#include
#include
void main()
{
int i;
char str[20];
printf("请输入一个字符:");
gets(str);
for(i=0;str[i]!='\0';i++)
if(str[i]!='c')str[j++]=str[i]; //将指定字符c删除
str[j]= '\0';
printf("请输入一个字符:");
puts(str);
}
运行结果:
(3) 设计程序sy6-3.c,输入一个字符串,统计其中'a' 到'z' 26 个英文小写字母各自出现的次数。例如运行时输入字符串:abcdefgabcdeabc 后,则输出的结果应该是:3 3 3 2 2 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
算法分析:
用a数组的a[0](其中0下标是'a'-'a')存放'a'字符的个数,a[1](其中1下标是'b'-'a')存放'b'字符的个数,a[str[i]-'a'](其中str[i]-'a'下标是str[i]字符对应存储个数的下标)存放str[i]字符的个数。因此在程序中只需用str[i]-'a'作为a下标的元素进行自加即可。
参考答案:
#include
void main()
{
char str[100];
int i,a[26]={0}; //分别统计26小写字母的个数,初始时都为0个
printf("请输入一个字符串:");
gets(str);
for(i=0;str[i]!='\0';i++)
if(str[i]>='a'&&str[i]<='z') //是小写字母才统计
a[str[i]-'a']++; //str[i]-'a'作为a数组下标的元素进行自加,
//即可使相应统计个数的元素值加一for(i=0;i<26;i++) //输出统计结果
printf("%c:%-3d",'a'+i,a[i]);
}
运行结果:
(4) 设计程序sy6-4.c,将一个数字字符串转换为一个整数(不得调用C 语言提供的将字符串转换为整数的函数)。例如,若输入字符串"-1234",则函数把它转换为整数值-1234。
算法分析:
将数字字符转换成数字的做法是,将该数字字符减去'0'字符,在转换时需要逐个字符判断为数字字符才转换,不是不转换。
为了保证转换的数字为一个原顺序的整数,则把s*10后再把转换后的数字累加入s中。最后再对字符串中的第一个字符进行判断看是否是‘-’;
如果是,则把s置成-s即可
参考答案:
#include
void main()
{
char str[100];
int i,s=0;
printf("请输入一个字符串:");
gets(str);
for(i=0;str[i]!='\0';i++) //逐一把每个数字字符转换累加到数s中
if(str[i]>='0'&&str[i]<='9') s=s*10+str[i]-'0';
if(str[0]=='-') s=-s; //判断符号位
printf("result=%d\n",s);
}
运行结果:
(5) 设计程序sy6-6.c,将放在字符串数组中的M 个字符串(每串的长度不超过N),按顺序合并组成一个新的字符串。例如,字符串数组中的M 个字符串为:AAAA BBBBBBB CC 则合并后的字符串的内容应是:AAAABBBBBBBCC。
算法分析:
首先对p串初始化为'\0'再将s中的每个字符串连接在p串的后边。但要注意将string.h 包含在程序中
参考答案:
#include
#include
#define M 3