C语言实验十 函数(二)

简介: C语言实验十 函数(二)

一、实验目的

(一)掌握函数的定义、函数类型、函数参数、函数调用的基本概念;

(二)掌握变量名作函数参数的程序设计方法;

(三)掌握函数的嵌套调用的方法;

(四)掌握数组元素作函数参数;

(五)掌握数组名作函数参数的程序设计方法;

(六)掌握字符数组作函数参数的程序设计方法;

(七)了解全局变量、局部变量的概念和使用方法;

(八)使用功能键F7单步执行,使用Ctrl+F7观察变量的值,学会程序调试基本方法。

二、预习要求

(一)函数的定义、函数类型、函数参数、函数调用的基本概念;

(二)函数实参与形参的对应关系以及参数的传递;

(三)以变量名和数组名作函数参数时的使用方法;

(四)全局变量、局部变量的概念和使用方法。

三、实验内容

(一)写一个程序,判别一个整数数组中各元素的值,若大于0 则输出该值,若小于或等于0则输出0值。

编程提示:

判断函数:

1.函数的类型为void,函数中不使用return语句;

2.函数的形参为一整型变量;

3.函数体中使用选择结构,根据对变量值的判断输出相应结果。

main函数:

1.定义一个一维整型数组;

2. 为整型数组赋若干个数值;

3. 调用判断函数对数组元素逐一进行判断,以数组元素作实参。

1. /*  c9-5.c  判别一个整数数组中各元素的值  */
2. #include "stdio.h"
3. void main()
4. {
5.  int as(int x);
6.  int x;
7.  printf("请输入整数:");
8.  scanf("%d",&x);
9.  as(x);
10.  } 
11. int as(int x)
12.  {
13.   int y;
14.   if(x>0)
15.   y=x;
16.   else
17.   y=0;
18.   printf("输出的值为:%d",y);
19.  }

(二)一维数组a中的元素为:1,4,2,7,3,12,5,34,5,9。求一维数组a中的最大元素及其下标。程序的输出应为:The max is: 34,position is: 7 。要求:求最大元素位置用函数实现,在main函数中调用该函数。

编程提示:

定义一个全局变量max,用来存放最大元素。求最大元素位置的子函数:

1.函数的类型为整型;

2. 函数的形参应为整型一维数组和一整型变量(存放数组元素的个数);

3.函数体中,定义一个整型pos,用来存放当前最大元素在数组中的下标,初值为0;将全局变量max的初值设置为数组中的第一个元素;

4. 函数体中使用循环结构,将数组元素依次和max中的值进行比较,将两者中的最大元素存入max中,并将最大元素的下标存入pos中;

5. 循环结束后,用return语句,将pos的值返回到主函数。

main函数:

1. 定义一个一维整型数组并为该数组赋若干个数;

2. 以赋值语句的形式,将求最大元素位置函数的返回值赋给一个变量,以数组名和数组的元素个数作实参。

注意:以数组名作实参时,实参与形参之间是地址的传递,实参数组和形参数组是公用一段内存单元。

1. /*   c9-6.c    通过函数调用求一维数组中的最大元素及其下标*/
2. #include "conio.h"
3. #include "stdio.h"
4. void main()
5. {
6.  int a[10]={1,4,2,7,3,12,5,34,5,9};
7.  as(a);
8. }
9. int as(int a[10])
10. {
11.   int i,k=0,max=a[0];
12.   for(i=0;i<10;i++)
13.   {
14.     if(max<a[i])
15.     {
16.     max=a[i];
17.     k=i;
18.     }
19.   }
20.   printf("最大元素和对应位置为:%d %d ",max,k);
21. }

(三)下面程序的功能是:求二维数组a中的上三角元素之和。

例如:a中的元素为:

       4    4    34   37

       7    3    12   8

       5    6     5    52

       24  23  2    10

程序的输出应为:The sum is:147。

1. /*   c9-7.c    通过函数调用求二维数组中的上三角元素之和*/
2. #include "conio.h"
3. #include "stdio.h"
4. void main()
5. {   
6.     int as(int a[4][4]);
7.  int a[4][4]={{4,4,34,37},{7,3,12,8},{5,6,5,52},{24,23,2,10}};
8.  int i,j; 
9.  as(a); 
10. }
11. int as(int a[4][4])
12. {
13.   int i,j,sum;
14.   for(i=0,sum=0;i<4;i++)
15.   for(j=0;j<4;j++)
16.   { 
17.   if(i<=j)
18.   sum=sum+a[i][j];
19.   }
20.   printf("输出的元素之和为:%d",sum);
21. }

(四)将字符串1的第1,3,5,7,9,......位置的字符复制到字符串2并输出。

例如:当字符串1为"This Is a c Program",则字符串2为"Ti sacPorm"。

编程提示:

子函数:

1. 函数的类型为void,函数中不使用return语句;

2. 函数的形参应为两个字符型一维数组;

3. 函数体中使用循环结构,将字符串1中相应位置上的字符逐一复制到字符串2中,注意循环变量每次递增的数目。

main函数:

1. 定义一个一维字符型数组;

2. 为字符数组赋一个字符串;

3. 调用转换函数,以两个数组名作实参;

4. 输出转换后的字符数组的内容。

1. /*   c9-8.c    通过函数调用实现对字符串的处理*/
2. #include "conio.h"
3. #include "stdio.h"
4. #include "string.h"
5. void main()
6.   { 
7.   void as(char str1[],char str2[]);
8.   char str1[80]={"This is a C program"},str2[80]={"Ti scaporm"};
9.    printf("原字符串为: %s\n",str1);
10.    printf("输出字符串: %s\n",str2);
11.   }
12. void as(char str1[ ],char str2[ ])
13. { 
14.     int i,j=0;
15. for(i=0;i<strlen(str1);i=i+2)
16.     {
17.   str2[j]=str1[i];
18.     j++;
19.   }
20.     str2[j]='\0';
21. }

四、实验注意事项

(一)定义函数时,函数名后的圆括号后面不能加“;”。

(二)在函数体内,不能再对形参进行定义和说明。

(三)变量作实参时,只使用变量名,实参变量对形参变量的数据传递是“值传递”。

(四)一维数组作函数的实参时,只使用数组名如:fun(a); 。

目录
相关文章
|
1月前
|
C语言 C++
C语言 之 内存函数
C语言 之 内存函数
32 3
|
4天前
|
C语言
c语言调用的函数的声明
被调用的函数的声明: 一个函数调用另一个函数需具备的条件: 首先被调用的函数必须是已经存在的函数,即头文件中存在或已经定义过; 如果使用库函数,一般应该在本文件开头用#include命令将调用有关库函数时在所需要用到的信息“包含”到本文件中。.h文件是头文件所用的后缀。 如果使用用户自己定义的函数,而且该函数与使用它的函数在同一个文件中,一般还应该在主调函数中对被调用的函数做声明。 如果被调用的函数定义出现在主调函数之前可以不必声明。 如果已在所有函数定义之前,在函数的外部已做了函数声明,则在各个主调函数中不必多所调用的函数在做声明
19 6
|
24天前
|
存储 缓存 C语言
【c语言】简单的算术操作符、输入输出函数
本文介绍了C语言中的算术操作符、赋值操作符、单目操作符以及输入输出函数 `printf` 和 `scanf` 的基本用法。算术操作符包括加、减、乘、除和求余,其中除法和求余运算有特殊规则。赋值操作符用于给变量赋值,并支持复合赋值。单目操作符包括自增自减、正负号和强制类型转换。输入输出函数 `printf` 和 `scanf` 用于格式化输入和输出,支持多种占位符和格式控制。通过示例代码详细解释了这些操作符和函数的使用方法。
33 10
|
18天前
|
存储 算法 程序员
C语言:库函数
C语言的库函数是预定义的函数,用于执行常见的编程任务,如输入输出、字符串处理、数学运算等。使用库函数可以简化编程工作,提高开发效率。C标准库提供了丰富的函数,满足各种需求。
|
23天前
|
机器学习/深度学习 C语言
【c语言】一篇文章搞懂函数递归
本文详细介绍了函数递归的概念、思想及其限制条件,并通过求阶乘、打印整数每一位和求斐波那契数等实例,展示了递归的应用。递归的核心在于将大问题分解为小问题,但需注意递归可能导致效率低下和栈溢出的问题。文章最后总结了递归的优缺点,提醒读者在实际编程中合理使用递归。
53 7
|
23天前
|
存储 编译器 程序员
【c语言】函数
本文介绍了C语言中函数的基本概念,包括库函数和自定义函数的定义、使用及示例。库函数如`printf`和`scanf`,通过包含相应的头文件即可使用。自定义函数需指定返回类型、函数名、形式参数等。文中还探讨了函数的调用、形参与实参的区别、return语句的用法、函数嵌套调用、链式访问以及static关键字对变量和函数的影响,强调了static如何改变变量的生命周期和作用域,以及函数的可见性。
29 4
|
28天前
|
存储 编译器 C语言
C语言函数的定义与函数的声明的区别
C语言中,函数的定义包含函数的实现,即具体执行的代码块;而函数的声明仅描述函数的名称、返回类型和参数列表,用于告知编译器函数的存在,但不包含实现细节。声明通常放在头文件中,定义则在源文件中。
|
21天前
|
存储 C语言
【c语言】字符串函数和内存函数
本文介绍了C语言中常用的字符串函数和内存函数,包括`strlen`、`strcpy`、`strcat`、`strcmp`、`strstr`、`strncpy`、`strncat`、`strncmp`、`strtok`、`memcpy`、`memmove`和`memset`等函数的使用方法及模拟实现。文章详细讲解了每个函数的功能、参数、返回值,并提供了具体的代码示例,帮助读者更好地理解和掌握这些函数的应用。
18 0
|
21天前
|
C语言
【c语言】qsort函数及泛型冒泡排序的模拟实现
本文介绍了C语言中的`qsort`函数及其背后的回调函数概念。`qsort`函数用于对任意类型的数据进行排序,其核心在于通过函数指针调用用户自定义的比较函数。文章还详细讲解了如何实现一个泛型冒泡排序,包括比较函数、交换函数和排序函数的编写,并展示了完整的代码示例。最后,通过实际运行验证了排序的正确性,展示了泛型编程的优势。
18 0
|
24天前
|
算法 C语言
factorial函数c语言
C语言中实现阶乘函数提供了直接循环和递归两种思路,各有优劣。循环实现更适用于大规模数值,避免了栈溢出风险;而递归实现则在代码简洁度上占优,但需警惕深度递归带来的潜在问题。在实际开发中,根据具体需求与环境选择合适的实现方式至关重要。
22 0