华中科技大学c第5次上机作业 .doc
《华中科技大学c第5次上机作业 .doc》由会员分享,可在线阅读,更多相关《华中科技大学c第5次上机作业 .doc(14页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、华 中 科 技 大 学计算机基础与程序设计(C+)实 验 报 告实验名称:第五次上机实验 实验学时:4姓名: 学号: 班级:电气实验日期: 2017/4/27 教师批阅签字:一、实验目的l 掌握字符型数组、字符型指针和数值型数组的异同 。l 掌握自定义函数的定义,声明和调用。l 掌握函数参数的值传递和地址传递的区别。l 掌握递归算法的意义。l 明确变量的作用域和生存期的意义。二、实验内容1阅读程序1)#include #includeusing namespace std;int main() int a=10, *p=&a; char ch=a, *q=&ch; char str =”abc
2、d”,*=str; cout*pendl; cout*qendl; cout*endl; coutpendl; coutqendl; coutendl;return 0;运行上述的程序,并解释每个输出结果。解释:1.指针变量*p指向a的地址,所以直接输出a的值。2.指针变量*q指向ch的地址,所以输出ch的值。3.指针变量*指向数组str的首地址,故只输出首个数据4.因为a的类型为int,所以输出了a的地址5. 有一个元素的字符数组,没有0,所以直接输出时不能停止,只能输出乱码,而字符串可以直接输出是因为它会自动添加0,输出时遇到0停止,所以可以正常输出;6. 用字符数组给指针初始化,所以相当
3、于str,而字符数组可以整体输出2)#include #includeusing namespace std;int main() int age ; char name11; cinage; ne(name,11); coutageendl; coutnameage后面的分号为中文2.ne会将输入的回车作为其结束的标志,故直接跳过了输入字符数组这一步骤。只需要用吸收这个回车即可。修改后的程序:#include #includeusing namespace std;int main() int age ; char name11; cinage; (); ne(name,11); couta
4、geendl; coutnameendl;return 0; 3) #include #include using namespace std;int main( )char rstr10 =abcdefgh, dstr10; char * p=rstr, *q=dstr; strcpy(dstr,rstr);cout输出字符串rstr:rstrendl; cout输出字符串dstr:dstrendl;cout输出字符串p:pendl; cout输出字符串q:qendl;return 0; 阅读上述程序并运行,分析其结果。若将上述程序修改如下,重新运行,结果如何?请解释原因。int main(
5、 )char *rstr=abcdefgh, *dstr; strcpy(dstr,rstr);cout输出字符串rstr:rstrendl; cout输出字符串dstr:dstrendl;return 0;上述程序的功能是将字符串rstr复制到目标串dstr中,运行该程序结果是否正确,如不正确请修改正确,并解释原因。原程序的结果:Srtcpy将rstr中的数据复制到了dstr中,所以会输出abcdefgh,输出p和q相当于间接输出,也可以输出abcdefgh。第二个程序:此程序无法运行,原因是指针*rstr和*dstr未指向安全的位置。更改会使程序无法运行。修改:#include #incl
6、ude using namespace std;int main( )char a10=abcdefgh,b10;char *rstr=a, *dstr=b; strcpy(dstr,rstr);cout输出字符串rstr:rstrendl; cout输出字符串dstr:dstrendl;return 0;解释:将指针指向安全的位置即可。2 编程题 1)编写两个函数,分别求两个整数的最大公约数和最小公倍数,在主函数中调用这两个函数,计算两个数的最大公约数和最小公倍数并输出结果。 要求:1) 程序原代码。(直接粘贴在此) #include using namespace std;int gys
7、(int,int);int gbs (int,int);int main( )int a,b;cout请输入两个正整数ab;cout最大公约数为gys(a,b)endl;cout最小公倍数为gbs(a,b)=b)n=a;elsen=b;for(i=2;i=b)n=a;elsen=b;for(i=2;i=n;i+)if(a%i=0&b%i=0)m=i;s=a*b/m;return s;2) 解决本题的算法思路描述 编写计算最小公倍数的函数编写计算最大公约数的函数在主函数中使用这两个函数得出结果 3) 调试过程的记载(包括出现的错误,以及修改) 函数声明方式错误4) 归纳本题应用的知识点或算法计算
8、最大公约数和最小公倍数的方法函数的声明与使用2)编写程序随机生成50个100-200之间的随机整数,找出其中的素数。要求判断素数的功能利用函数实现,在main函数中调用该函数输出所有的素数。要求:1) 程序原代码。(直接粘贴在此) #include #include #include using namespace std;int ss (int);int main( )int a50,i,t=0,j;srand(time(0);a0=(rand()%100+100);for(i=1;i50;i+)t=0;ai=(rand()%100+100);for(j=0;ji;j+)if(ai=aj)
9、t=1;if(t=1) i-;cout生成的50个随机数为:endl;for(i=0;i50;i+)coutai ;if (i+1)%5=0) coutendl;cout其中的素数为:endl;for(i=0,j=0;i50;i+)if(ss(ai)coutai ;j+;if(j%5=0)coutendl;coutendl;return 0;int ss (int b)int a=1,n;for (n=2;nb;n+)if (b%n=0)a=0;break;return a; 2) 解决本题的算法思路描述 编写一个求素数的函数主函数中定义一个含50个元素的数组 当该变量的值位于100到200之
10、间时,将该变量的值赋给数组中的元素,并与前面所有值进行比较,若重复,则重新赋值。不断循环,直到数组中的每个数都被赋值输出数组中的各个数,依次用求素数的函数判断该数组中的元素是否为素数,是则输出。3) 调试过程的记载(包括出现的错误,以及修改)编写求素数的函数时,i从0开始,导致循环无法实现。4) 归纳本题应用的知识点或算法For循环,break语句的使用函数的调用生成随机数函数的使用if语句及数组 3)编写一个函数实现将一个十六进制整数转换为一个十进制整数。例如,输入”A2”转换为162。提示:循环对读入的每个字符转换成对应的十进制数字,比如1的值为1,A为10,F为15,将转换后得到的数字进
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 华中科技大学c第5次上机作业 华中科技大学 上机 作业
限制150内