




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、实验七 函数参考程序一、程序调试方法实验1.找出并改正以下源程序中错误,得出正确的运行结果。源程序如下:#include <stdio.h> /函数声明 int add(int a, int b);void main()int a,b;scanf("%d%d",&a,&b);printf("a+b=%d",add(a,b);void add(int a,b) /改为int add(int a, int b)return a+b;2.找出并改正以下源程序中错误,得出正确的运行结果,其中max函数的功能是得到数组中最大元素的值。源
2、程序如下:#include <stdio.h>#define N 10; /去掉尾部分号float max(float a, int n) /尾部加上分号void main()float dataN;int i;for(i=0;i<N;i+)scanf("%f",datai); /改为scanf("%f", &datai);printf("max is=%f",max(dataN,N); / 改为printf("max is=%f",max(data, N); float max(floa
3、t a, int n)int i,result; /改为 int i; float result; /增加result=a0;for(i=0;i<n;i+)if(ai > result)result = ai;return result;3.找出并改正以下源程序中错误,得出正确的运行结果,其中converse函数的功能是逆序输出n个字符。解题思路:已知字符串的长度,逆序输出字符串如果只有1个字符,直接输出该字符后结束否则:输出后面的所有字符之后,再输出该字符源程序如下:#include <stdio.h>void main() int i=5; void convers
4、e(int n); printf("Input 5 characters:"); converse(i); printf("n"); void converse(n); /改为void converse(int n) 并去掉分号char next; if(n>=1) /改为 if(n= =1) next=getchar(); putchar(next); else next=getchar(); converse(n-1); putchar(next); 四、编写程序1、编写一个函数,其功能是判断形式参数是否为小写字母,若是,返回其对应的大写字母,
5、否则返回原字符。然后在main函数中输入一个字符,调用该函数得到其大写字母并输出#include <stdio.h>char isLow(char ch) if(ch >= 'a' && ch <= 'z') return ch - 32; else return ch;void main(void) char ch; printf("请输入一个字符:n"); scanf("%c",&ch); printf("%cn", isLow(ch);2、编写函数r
6、everse(int number),它的功能是将number逆序输出,在main函数中输入一个整数,调用该函数得到逆序的数并输出。例如reverse(11233)的返回值为33211。#include <stdio.h>int reverse(int n) int rev=0,num; do num=n %10; rev = rev*10 + num; n=n/10; while(n); return rev;void main(void) int num,revnum; printf("请输入一个整数:n"); scanf("%d",&a
7、mp;num); revnum = reverse(num); printf("逆序后整数为:%dn",revnum); 3、编写函数完成如下功能:将长整型数中数字为偶数的数依次取出,构成一个新数返回,例如,当s中的数为:87653142时,则返回的数为:8642。提示:依次取出长整型数的每一位数字,如果是偶数,则放入新数中。在main函数中输入一个长整型数,调用该函数得到新的数,并输出结果。#include "stdio.h"long func(long s);void main()long a;printf("请输入一个整数:")
8、;scanf("%ld",&a);printf("%ldn",func(a);long func(long n) long result=0;int num, weight=1 ; / weight表示数位的权值(即个、十、百,。)while ( n != 0 )num = n%10; /得到最低位if (num % 2=0) result= num * weight + result; /重新组织成新的数 weight=weight * 10;n/=10; /去掉最低位return (result);4、编写一个函数sort,实现数组元素的升序
9、(或降序)排列。在main函数中输入数组元素,调用该函数进行排序,最后输出排序后的结果。#include <stdio.h>#define N 10void sort(float a, int n) /无返回值,在原数组上排序并带回 int i,j; float temp; for(i=0;i<n-1;i+) /*冒泡排序*/ for(j=i+1;j<n;j+) if(ai>aj) temp = ai; ai = aj; aj = temp; void main(void) float aN; int i; printf("请输入%d个数值:n"
10、;,N); for(i=0;i<N;i+) scanf("%f",&ai); sort(a, N); printf("升序排序后的数组为:n"); for(i=0;i<N;i+) printf("%6.2f",ai); printf(”n”);5、编写函数求出二维整型数组中元素的最大值及其下标号。提示:这里至少需要返回二维数组元素的行,列两个值,而函数只能返回1个值(无法返回2个值),所以只能通过数组作为参数的方法将值带回来。在main函数中输入一个二维整型数组,调用该函数得到最大值所在的下标,并输出最大值及其下标
11、号。#include <stdio.h>void max_value(int array4, int index) /没有返回值的函数,结果通过与index对应的数组带回int i,j,max;max=array00;for(i=0; i<3; i+)for(j=0; j<4; j+)if(max < arrayij) index0 = i;index1 = j;max = arrayij; void main()int a34=18,2,3,4,8,7,6,5,9,10,11,12;int maxindex2=0; /定义数组maxindex以保存最大值的行、列
12、下标,因为函数无法返回2个值,只能通过数组带回来int i, j; max_value(a, maxindex);i=maxindex0;j=maxindex1;printf("Max=array%d%d=%dn",i,j,aij);6、编写函数,统计给定字符串中各个字母出现的次数,不区分大小写。在main函数中输入一个字符串,调用该函数进行计算,然后输出统计结果。提示:统计结果可以保存到一个数组中,如int count26,分别存储每个字母出现的次数,初值0,然后将数组作为函数参数将值带回来。#include "stdio.h"void fun(cha
13、r s, int a) /将统计26个字母的结果存放在与数组a对应的实参中int i, j;for(i=0; si; i+)if(si >= 'A' && si <= 'Z')j = si-'A' /得到该字母在26个字母中的序号else if(si >= 'a' && si <= 'z')j = si-'a'aj+; /对应字母的个数加1 int main(void) char str80; int count26=0, i; /count数
14、组26个元素分别存储每个字母出现的次数,初值0 printf("请输入一串字符以回车键结束:n"); gets(str); fun(str, count); /输出统计结果 for(i=0; i<26; i+) if(counti!=0) printf("%c或%c出现的次数为:%dn",'a'+i, 'A'+i, counti);7、编写函数substring(char , char sub),查找sub串在字符串s中第一次出现的下标位置。提示:若找到,函数返回对应下标,否则返回-1。例如s串为“abcdefg”,
15、sub串为“def”,则返回值为4。在main函数中输入主串和子串,调用该函数并输出结果。#include <stdio.h>#include <string.h>int substring(char s, char sub) /查找sub在s中第一次出现的位置,若找到返回对应下标,否则返回-1 int end, i, j; end = strlen(s) - strlen(sub); /* 计算结束位置*/ if ( end > 0 ) /* 子串sub小于字符串s */ for ( i = 0; i <= end; i+ ) /* 用循环从首字符开始依次
16、比较 */ for ( j = 0; subj; j+ ) if(si+j != subj) break; if ( subj = '0' ) /* 找到(即sub中所有字符都匹配),返回位置 */ return i + 1; return -1; /*未找到,返回-1*/ void main(void) char string100; char substr100; int result; printf("请输入字符串: "); gets(string); /* 读取字符串*/ printf("请输入要搜索的子字符串 => ");
17、 gets(substr); /* 读取子字符串*/ result = substring(string,substr); /* 定位子字符串*/ if ( result > 0 ) printf("子字符串 %s 位置在 %dn",substr, result); else printf("没有找到子字符串 %sn", substring);8、请编一个函数fun,其中n所指存储单元中存放了数组中元素的个数。函数的功能是:删除所有值为y的元素。已在主函数中给数组元素赋值,y的值由主函数通过键盘读入。注意:部分源程序已给出,请勿改动主函数和其他函数
18、中的内容,仅在函数fun的指定的部位填入你编写的若干语句。源程序如下:#include <stdio.h>#define M 20int fun(int bb,int n, int y)int i,j;for(i=0;i<n;i+)if(bbi=y) /当某个元素等于y时,把i后的元素顺次往前挪动一个位置for(j=i;j<n-1;j+)bbj=bbj+1;n-;i-;return n;void main() int aaM=1,2,3,3,2,1,1,2,3,4,5,4,3,2,1, n=15, y, k;printf("The original data
19、is: n");for(k=0; k<n; k+ ) printf("%d ",aak);printf("nEnter a number to deleted: "); scanf("%d",&y);n = fun(aa, n, y);printf("The data after deleted %d: n",y);for(k=0; k<n; k+ ) printf("%d",aak);printf("nn");第七课后习题7、8、9参考程序7、
20、/* 在字符串中插入子串 */#include <stdio.h>#include <string.h>void insert(char s1, char s2, int pos)int len1, len2, i, j, k;len1=strlen(s1);/*计算字符串1的长度*/len2=strlen(s2); /*计算字符串2的长度*/if(pos>len1) /*插入位置是字符串的尾部*/pos=len1;else if(pos<0) /*插入位置是字符串的头部*/pos=0;k=len1+len2; /*计算新字符串的长度*/ for(i=len
21、1-1, j=k-1; i>=pos; j-, i-) /*将插入点后字符移至串1尾部*/s1j=s1i;s1k='0'for(i=pos, j=0; s2j; i+, j+) /*将字符串2插入到字符串1中*/s1i=s2j;void main(void)char s180, s220; /假定输入时串1不超60字符,串2不超20字符int pos;printf("请输入字符串1: n");gets(s1);printf("请输入字符串2: n");gets(s2);printf("请输入将字符串2插入字符串1的位置: n");scanf("%d", &pos);insert(s1, s2, pos-1);printf("插入字符串2后的字符串1为: %sn", s1);8、/*输出字符串中最长的单词*/#include<stdio.h> #include<string.h>void longword(char s1, char s2)char word100=0; /*初始化为空字符*/ int i=
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 三年级道德与法治上册第一单元快乐学习1.1学习伴我成长第1课时教案新人教版
- 2025届山西省吕梁学院附中高考数学试题全真模拟密押卷(八)含解析
- 2024秋四年级语文上册第七单元24延安我把你追寻教学反思参考1新人教版
- 江苏省泰州市三中学教育联盟重点达标名校2024-2025学年初三一诊考试-英语试题含答案
- 深度学习在编程中的应用-全面剖析
- 机器翻译质量评估体系构建-全面剖析
- 菏泽市社区工作者招聘真题2024
- 基于译码器的多语种教育平台开发研究-全面剖析
- 云计算支持下的航空货运代理人供应链协同-全面剖析
- 浮式风电技术-全面剖析
- 《我的心灵疗愈》
- 中国教育史(第四版)全套教学课件
- 2022年4月自考02400建筑施工(一)试题及答案含评分标准
- 志愿者申请登记表
- 第七讲-信息技术与大数据伦理问题-副本
- 债权转让执行异议申请书范本
- 大学英语说课
- (完整版)数字信号处理教案(东南大学)
- 向政府申请项目资金申请报告
- 旅游心理学个性与旅游行为课件
- 超越广告-南京林业大学中国大学mooc课后章节答案期末考试题库2023年
评论
0/150
提交评论