《程序设计基础(C)》实验教程.doc

上传人:飞****2 文档编号:52751308 上传时间:2022-10-23 格式:DOC 页数:50 大小:590KB
返回 下载 相关 举报
《程序设计基础(C)》实验教程.doc_第1页
第1页 / 共50页
《程序设计基础(C)》实验教程.doc_第2页
第2页 / 共50页
点击查看更多>>
资源描述

《《程序设计基础(C)》实验教程.doc》由会员分享,可在线阅读,更多相关《《程序设计基础(C)》实验教程.doc(50页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、程序设计基础实验教程对于从事计算机行业的人员来说,设计能力是最主要的基本功之一。入门课程程序设计基础的学习效果将直接关系到编程能力的掌握和提高以及后续课程的学习。然而,实践证明,许多初学者在学习这门课程时的效果并不理想。对初学者来说,如何学好本课程?首先,要理解教材中所给出的语法描述,并学会按语法规定去编写指定问题的求解程序。经过这样的多次反复,初学者就可以找到编程的感觉。除了要学好理论知识外,更重要的一点是要到计算机上去验证,因为只有实践才是检验真理的标准。只有通过到计算机上去实践,才能发现学习中存在的问题,巩固所学知识,加强解决实际问题的能力,增强信心。因此,程序设计基础课程的上机实验是本

2、课程必不可少的实践环节,必须加以重视。本课程上机实验的目的是使学生熟悉用高级语言解决实际问题的全过程,加深对语言的理解,得到程序设计基本方法和能力的训练。在独立编写程序、独立上机调试程序的同时,真正能用高级语言这个工具去解决实际问题,对计算机学科的相关知识有所了解,从而为后续课程的学习奠定良好的基础。本实验指导所用环境是Visual C+ 6.0及以上版本。考虑到本课程的内容和特点,设置了十三个实验,每次实验需要两至三小时,分别侧重于教材中的一个方面,其中标有“*”号的习题的综合性较强,可供学有余力的学生选择。实验时也可根据具体情况做适当调整。虽然可能由于课时和机时限制等原因而不能在实验课时内

3、全部得到安排,但还是建议学生能将其中的每个实验都能认真做一遍,因为这些实验都是学习本课程所必需的。学生在做实验之前应仔细阅读本实验指导书,初步掌握实验的基本要求和实验方法。在实验过程中,学生应该有意识的培养自己调试程序的能力,积累发现问题、解决问题的经验,灵活主动的学习。对于分析运行结果的实验习题,上机前先进行用人工分析,写出运行结果,与上机调试得到的结果进行对照,如有差异,分析其原因。对于程序编制的实验习题,上机前应考虑出较成熟的编程思路,有意识提供出多种方案,以灵活运用所学知识和技巧。如此,可充分利用有限的上机时间,有目的的增强调试程序、解决各种实际问题的能力。每个实验完成后需要写实验报告

4、。实验报告格式参见附录一。实验Visual C+ 集成开发环境1. 实验目的要求(1) 熟悉和掌握Visual C+ 的集成开发环境(简称为IDE)的部分功能。(2) 熟悉和掌握建立控制台应用程序(3) 掌握用IDE编辑、编译和运行简单程序的基本过程。(4) 掌握程序调试的基本方法,包括程序断点的设置与去除,程序的跟踪以及运行期间变量数值的观察。2. 实验内容(1) 了解Visual C+可视化集成开发环境Visual C+是微软公司推出的目前使用极为广泛的基于Windows平台的可视化集成开发环境,它和Visual Basic、Visual Foxpro、Visual J+等其它软件构成了V

5、isual Studio(又名Developer Studio)程序设计软件包。Developer Studio是一个通用的应用程序集成开发环境,包含了一个文本编辑器、资源编辑器、工程编译工具、一个增量连接器、源代码浏览器、集成调试工具,以及一套联机文档。使用Developer Studio,可以完成创建、调试、修改应用程序等的各种操作。Visual C+分为学习版、专业版和企业版。VC提供了一种控制台操作方式,初学者使用它应该从这里开始。Win32控制台程序(Win32 Console Application)是一类Windows程序,它不使用复杂的图形用户界面,程序与用户交互时通过一个标准

6、的正文窗口,通过几个标准的输入输出流(I/O Streams)进行。下面我们将对使用VC编写简单的控制台程序作一个最初步的介绍。这里的介绍不包含C+运行环境(尤其是Windows环境)下进行开发的内容,有关这方面的内容请参阅相应开发手册。另外,Visual C+包含丰富的函数库和类库,学生在设计程序时可以使用有关的内容,这方面的内容也请自行参阅相应的开发指南类书籍。实验操作步骤如下:安装Visual C+ :运行Visual Studio软件中的setup.exe程序,选择安装Visual C+ 6.0,然后按照安装程序的指导完成安装过程。启动Visual C+ :安装完成后,在开始菜单的程序

7、选单中有Microsoft Visual Studio 6.0图标,其中又有Microsoft Visual C+ 6.0即可运行(也可在Window桌面上建立一个快捷方式,以后可双击运行)。Visual C+ 6.0开发环境见图0-1。建立控制台工程:进入Visual C+ 环境后,选择菜单“File | New”,在弹出的对话框中单击上方的选项卡“Projects”,选择“Win32 Console Application”工程类型,在“Project name”一栏中填写工程名例如MyFirst,在“Location”一栏中填写工程路径(目录)例如:D: MyProjectMyFirst

8、,见图0-2,然后按“OK”继续。图0-1 启动Mircosoft Visual C+ 6.0图0-2 创建控制台工程屏幕上出现如图0-3所示的Win32 Console ApplicationStep 1 of 1对话框后,选择“An empty project”项,然后按Finish按钮继续,图0-3 Win32 Console ApplicationStep 1 of 1对话框出现如图0-4所示的New Project Information 对话框后,按OK按钮完成工程创建。图0-4 New Project Information 对话框编辑C+程序:选择菜单“Project | Ad

9、d to Project | New”,为工程添加新的C+源文件。如图0-5所示。图0-5 选择菜单为工程添加新源文件图0-6 加入新的C+ Source File在出现如图0-6所示的对话框后,选择“File”选项卡,选定“C+ Source File”项,在“File Name”栏填入新添加的源文件名,如MyFirst.cpp,“Location”一栏指定文件路径,按按钮“OK”完成C+源程序的系统新建操作,如图0-6所示。在文件编辑区输入源程序,存盘,如图0-7所示。图0-7编辑 MyFirst.cpp源程序编译源程序:选择Build | Build菜单(F7为快捷键),系统将会在Out

10、put窗口给出所有的错误信息和警告信息。当所有错误修正之后,系统将会生成扩展名为.exe的可执行文件。对于Output窗口给出的错误信息,双击可以使输入焦点跳转到引起错误的源代码处以进行修改。执行程序:选择Build | Execute菜单项(Ctrl + F5为快捷键),执行程序,将会出现一个DOS窗口,按照程序输入要求正确输入数据后,程序即正确执行。如图0-8所示。调试程序:在编写较长的程序时,能够一次成功而不含有任何错误决非易事,这需要进行长期大量的练习。编写的程序若已没有编译错误,可以成功运行。对于程序中的错误,VC提供了易用且有效的调试手段。在工具栏上单击鼠标右键,在弹出的菜单中选中

11、“Debug”项。在程序调试状态下,可以进行单步执行调试程序。其中,单步跟踪进入子函数(Step Into,F11),每按一次F11键,程序执行一条无法再进行分解的程序行;单步跟踪跳过子函数(Step Over,F10),每按一次F10键,程序执行一行;Watch窗口可以显示变量名及其当前值,在单步执行的过程中,可以在Watch窗口中加入所需观察的变量,辅助加以进行监视,随时了解变量当前的情况;同时,为方便较大规模程序的跟踪,可以设置断点(F9为快捷键),断点处所在的程序行的左侧会出现一个红色圆点。选择Build | Start Debug | Go时,程序执行到断点处程序将暂停执行,可方便用

12、户进行变量观察。取消断点只需在代码处再次按F9即可。还有运行至当前函数的末尾(Step Out)等都是很有效的调试工具,这里不再做一一介绍。图0-8 程序运行结果图0-9 MSDN有关联机帮助:Visual C+6.0提供了详细的帮助信息,用户通过选择集成开发环境中的“Help”菜单下的“Contents”命令就可以进入帮助系统。在源文件编辑器中把光标定位在一个需要查询的单词处,然后按F1键也可以进入Visual C+6.0的帮助系统。如图0-9所示。用户要使用帮助必须安装MSDN。用户通过Visual C+6.0的帮助系统可以获得几乎所有的Visual C+6.0的技术信息,这也是Visua

13、l C+作为一个非常友好的开发环境所具有的一个特色。3. 思考题通过创建项目文件的实验,总结一下创建一个控制台应用项目的一般方法和经验。除了已经介绍过的调试方法,可以尝试集成开发环境提供的其它功能。实验一 面向过程的简单程序设计1.实验目的要求(1) 使用C+语言编写简单的计算机程序,掌握C+程序从编辑、编译到运行的全过程,初步了解C+程序的特点。(2) 掌握C+语言的数据类型(包括对各种数据类型变量的定义、初始化、赋值等)、运算符和表达式的使用。(3) 掌握赋值语句的使用。(4) 掌握数据的输入输出方法。2.实验内容(1)设计简单程序,分别计算下列表达式,式中变量由键盘输入,输出表达式的值。

14、 sinX+cosX+tan-1X ex+y+ex-y log10(1+) + (其中表示取不大于a的最大整数)。(2)阅读下列程序,写出(由指定的输入)所产生的运行结果,并指出其功能。 #include void main()char ch;cin ch ;ch = ( ch = A & ch = a & ch = z ) ? ( ch 32 ) : ch ;cout ch endl; #include void main()int m;float x;bool bi,br;cout m;bi = m 1000;cout x;br = x = 1e3;cout bi , br endl;分别

15、输入100 40,2000 3000,1000 1000,2000 300,100 4000 运行。#include void main() int n;cin n ;if ( n + 10 ) cout n endl ;else cout n - endl ;(3)编写程序实现下列问题的求解。 根据随机从键盘输入的圆半径值,求圆的周长和半径并输出。 读入三个整数a、b、c,交换它们中的数,使a存放b的值,b存放c的值,c存放a的值。 对任意输入的四位整数,分别求出其各位数字,并按从后到前的顺序依次输出。例如,输入为1234时,输出结果为4,3,2,1。3.思考题* 对任意输入的小于1的并且只

16、有3位尾数的实数,分别求出其各位数字并输出。要求输出的各数字之间要空2格。例如,输入为0.368时,输出结果为0 3 6 8。实验二 控制结构程序设计1.实验目的要求(1) 理解基本的解题技巧,掌握用自顶向下、逐步求精的过程设计算法。(2) 熟练掌握if/else语句和switch语句的使用。(3) 熟练掌握while语句、do/while语句和for语句的使用以及区别。(4) 掌握break和continue程序控制语句的使用。2.实验内容(1)阅读下列程序,写出(由指定的输入)所产生的运行结果,并指出其功能。 #include void main()int m,n;m = 1000;n =

17、 850;cout “n(“ m , n n ) m = m n ;cout ( m , n );while ( m n ) n = n m ;cout ( m , n ); cout “n” m ;#include void main()int m,n,k ;m = 1000 ;n = 45 ;cout “n(“ m : n =n )m = m n ;k = k + 1 ; cout k “-” m endl ;#include void main()int i;for ( i = 1 ; i = 5 ; i + )if ( i % 2 ) cout *;else continue;cout

18、 # ;cout “$n” ; #include void main()int a = 1,b = 10;dob -= a ;a + ;while ( b - = 0 ) ;cout “a=” a “b=” b endl ;(2)编写程序实现下列问题的求解。 求解下面函数的值。 ex+y x0,y0 z= ln(x+y) 1x+y10 log10|x+y|+1 其它情况 编程求解下列各计算式: 1) 2) ! 3) 4)Y=X(-1)n+1的值,精确到10-6。 打印下面图形。 1 1 3 1 1 3 5 3 1 1 3 5 7 5 3 1 1 3 5 7 9 7 5 3 1 1 3 21 3

19、 1 编程产生出1到10以内的所有数对并输出,其中ij。 编程求出10000以内的所有符合如下条件的数:其高位数字小于低位数字。如12,238,3578等。但21,548不符合条件。 求任一整数N的标准分解式,即素数因子之积。例如16=2*2*2*2, 15=3*5。3.思考题* 编程求出数列的所有升或降的最大子序列。如下面数列的解为如下: 1,20,30,12,3,5,7,4,6,100,11,8 (1,20,30),(30,12,3),(3,5,7),(7,4),(4,6,100),(100,11,8)。* 编程求12100的末三位数。实验三 数 组1.实验目的要求(1) 掌握一维数组和二

20、维数组的定义、初始化赋值、元素引用的方法。(2) 初步了解数组名与地址的关系。(3) 掌握字符数组和字符串函数的使用。(4) 掌握与数组有关的算法(特别是排序和查找算法)。2.实验内容(1)阅读下列程序,写出其运行结果,并指出其功能。#include #define N 10void main()int aN;int s,i,j,t;for ( i = 0 ; i N ; i + )if ( i % 2 ) a i = i * i ;else a i = 100 - ( i / 2 ) * ( i / 2 ) ; for ( i = 0 ; i N ; i + ) cout a i ;cout

21、 endl ;s = 0 ;for( i = 0 ; i N ; i + ) s = s + a i ;cout “sum of a = ” s ;for(i = 0 ; i = 0 & t a j ) a j + 1 = a j ;j - ;a j + 1 = t ;for( i = 0 ; i N ; i + ) cout a i ;cout endl ;#include #include void main( )char a 20 = ”TER” , b 20 = ”COMP” ;int i = 0 ;strcat( a , b ) ;while (a i + != 0 ) b i =

22、a i ;cout b ; #include void main( )int i = 0 , base , n , j , num 20 ;cin n base ;doi +;num i = n % base ;n = n / base ;while ( n != 0 );for ( j = i ; j = 1 ; j-) cout num j ;(2)编写程序实现下列问题的求解。 编程产生下列数组,并输出。 一维数组 1) (1 4 9 16 25 36 49 64 81 100) 2) (1 3 6 10 15 21 28 36 45 55) 3)(1 2 3 5 8 13 21 34 5

23、5 89) 二维数组 1) 1 2 3 4 5 6 2) 1 2 3 .n-1 0 2 3 4 5 6 0 2 3 4 . 0 1 3 4 5 6 0 1 3 4 5 . 1 2 4 5 6 0 1 2 . 5 6 0 1 2 3 n-1 0 1 .n-3 n-2 6 0 1 2 3 4 0 1 2 .n-2 n-1 3) 1 2 3 4 5 6 4) A B C D E F 2 1 2 3 4 5 B C E H L Q 3 2 1 2 3 4 C D F I M R 4 3 2 1 2 3 D E G J N S 5 4 3 2 1 2 E F H K O T 6 5 4 3 2 1 编程

24、实现数组的排序:将有15个元素的整型数组按从小到大的次序排序。 编程求一组整数的最大公因子和最小公倍数。 随机输入一组数组元素值,利用题使一个数组有序。然后随机输入一个数,用折半查找法在数组中查找,如在数组中,则输出元素在数组中的位置;如不在,则输出提示。 将两个字符串连接起来,不要用strcat。3.思考题 用数组存储数据,实现筛选法求素数问题的求解。要求求出2到1000之间的所有素数。注意: 筛选法求出2N间的所有素数的方法是:首先将这些数全部放入一个数组中,然后重复下面的操作直到数组为空为止: a.找出其中的最小数K,则K一定是一个素数,因此可输出。 b.从数组中删除K及其所有倍数。 判

25、断一个二维数组是否有“鞍点”,即该位置上的元素在该行上最大,在该列上最小。如有,输出其行列号和值;若无,给出提示。(数组元素的值用scanf输入) 编写程序将一个16进制数转换为十进制。任意进制如何转换为十进制? 本实验内容(1) 习题所完成的功能是否有不完备之处?若有,请完备这个程序。实验四 函 数1.实验目的要求(1) 理解并掌握如何模块化的用函数来构建程序。(2) 掌握定义函数的方法,了解函数的重载方法,了解内联函数的机制。(3) 掌握函数间传递信息的机制。(4) 掌握函数的嵌套调用(和递归调用)的方法。(5) 掌握全局变量和局部变量、动态变量和静态变量的概念和使用方法。2.实验内容(1

26、)阅读下列程序,写出其运行结果,并指出其功能。 #include int hcf( int u , int v )int a,b,t,r;if (u v)t = u ;u = v ;v = t ;a = u ;b = v ;while ( ( r = b % a ) != 0 )b = a ;a = r ;return( a ) ;int lcd( int u , int v , int h )return( u * v / h ) ;void main()int u , v , h , l ;cin u v ;h = hcf ( u , v ) ;cout “hcf=” h endl ;l

27、= lcd ( u , v, h ) ;cout “lcd=” l endl ;输入:48,32#include long fib ( int g )switch ( g )case 0 : return 0;case 1 :case 2 : return 1;return ( fib( g 1 ) + fib( g 2 ) ) ;void main ( )long k;k = fib ( 7 );cout “k=” k endl ;#include int k = 1 ;void main()int i = 4 ;int fun (int);fun( i ) ;cout “(1) “ i ,

28、 k endl ;fun( int m )m += k;k += m;char k = B;cout “(2)” char(k-A) endl ;cout “(3)” m , k endl ;# include # include void subp ( )static int x = 0 , y = 0 ; /*问题(1)*/int a, b;a = x y ; b = x + y ; cout setw(5) a setw(5) b endl ;cout setw(5) x setw(5) y endl ;int x , y ;void main()int a = 9,b = 3; x =

29、 a b ; y = a + b ;subp();cout setw(5) a setw(5) b endl ;cout setw(5) x setw(5) y endl ;1)运行结果是:2)如果问题(1)处语句改为static int x,y ; ,运行结果会发生改变么?为什么?(2)编写程序实现下列问题的求解。 求方程ax2+bx+c=0的根,用三个函数分别求b2-4ac大于0、等于0和小于0时的根,并输出结果。从主函数输入a、b、c的值。 用函数实现将一个以字符串形式表示的十六进制数转换为一个十进制整数。例如,输入”A2”转换为162。 编写一个将十进制整数转换为十六进制字符串的函数。

30、 编写出判断一个整数是否为素数的函数,并求出在2000以内的有十个以上的所有连续的非素数组。3.思考题(1) 本实验内容(2)1中,是否考虑了程序的完备性?考虑a、b、c等于零的各种情况,完备程序。*(2) 用递归和递推两种形式编程求函数 n(x)。n(x)定义为: 0(x)=1 1(x)=2x n(x)=2xn-1(x)-2(n-1)n-2(x) n1实验五 指 针1.实验目的要求(1) 掌握指针的概念,学会定义和使用指针变量。(2) 学会使用数组指针和指向数组的指针变量。(3) 学会使用字符串指针和指向字符串的指针变量。(4) 了解指向指针的指针的概念以及其使用方法。(5) 掌握指针、引用

31、、数组做函数参数的传递机制。(6) *学会使用指向函数的指针变量。2.实验内容(1) 阅读下面程序,写出其运行结果。#include sub ( int x , int y , int *z ) *z = y x ;void main( )int a,b,c;sub( 10 , 5 , &a ) ;sub( 7, a, &b ) ;sub( a, b, &c ) ;cout a , b , c endl ;#include #include void main()int stre ( char ) ;char str 10 , *p = str ;gets ( p ) ;cout stre (

32、 p ) endl ;int stre ( char str )int num = 0 ;while( * ( str + num ) != 0 ) num + ;return ( num ) ;(2) 编写程序实现下列问题的求解。1 输入三个整数,按由小到大的顺序输出,然后将程序改为:输入三个字符串,按由小到大的顺序输出。2 将一个3*3的矩阵转置,用一个函数实现。在主函数中用scanf输入以下矩阵元素:2,4,6,8,10,12,14,16,18。将数组名作为函数参数。函数调用后在主函数中输出已转置的矩阵。3 自己写一个strcmp函数,实现两个字符串的比较。两个字符串s1,s2由main

33、函数输入,strcmp函数的返回值也在main函数中输出。4 动态链表的每个结点包括一个整数和一个后继指针。分别编写过程完成如下操作: (1) 从键盘输入数据建立链表,并按数据的输入顺序建立链表。 (2) 依次打印其中各结点的数据。(3)*按与链表结点相反的次序打印各结点的值。(4) 逐个释放所有结点的存储单元。3.思考题(1) 自定义函数完成strcpy、strcat、strlen等字符串函数的功能,比较实验三中实验内容(2) 用数组处理的区别。(2) 用指向指针的指针的方法对n个整数排序并输出。要求将排序单独写成一个函数。N和各整数在主函数中输入。最后在主函数中输出。实验六 结构和联合类型

34、以及编译预处理1.实验目的要求(1) 掌握结构类型变量、联合类型变量的定义和使用,以及两者在内存中分配空间时的区别。(2) 掌握结构类型数组的概念和使用。(3) *掌握链表的概念,初步学会对链表进行查找、插入、删除、排序等操作。(4) 掌握宏定义、文件包含、条件编译的方法。2.实验内容(1) 阅读下面程序,写出其运行结果。#include union pwint i ;char ch 2 ;a;void main()a.ch 0 = 13 ;a.ch 1 = 0 ;cout “size=” sizeof(a) n “a.i=” a.i ;#include #define LETTER 0voi

35、d main()char str 20 = ”C Language” , c ;int i = 0 ;while ( (c = str i ) != 0 ) i + ;#if LETTERif ( c = a & c = A & c= Z )c = c + 32 ;#endifcout c ;(2) 请原样录入下面两个程序并调试运行,注意程序编译时错误、错误的位置及产生错误的原因,并加以改正,检查程序运行结果是否正确,若不正确请修改。程序1:#include #define PI 3.;#define AREA(r) PI * r * r;int main() double radius, s

36、; cout radius; s = AREA(radius); cout radius= radius The area is s n; s = AREA( radius + 1 ); cout radius= ( radius + 1 ) The area is s n; return 0;程序2:#include const float Pi = 3.1415.926;inline float area(const float r) return Pi * r * r;int main() double radius, s; cout radius; s= area(radius); cout radius=radius The area is s n; s= area(radius+1); cout radius=(radius+1) The area is s n; return 0;(3)编写程序实现下列问题的求解。 在某系的成绩登记册中,每个班最多有40个学生,每份成绩表中的成绩信息包括:学号(9位字符),姓名(8位字符),成绩(百分制),备注(20位字符)。设计程序以处理一个班级的成绩信息,包括输入、输出、查询(给定分数以上或以下的学生信息)、按分数排序等。 *建立一

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁