C语言---函数详解

目录

1. 函数是什么?

2. C语言中函数的分类

     2.1 库函数

     2.2 自定义函数

​3. 函数的参数

     3.1 实际参数(实参)

     3.2 形式参数(形参)

4. 函数的调用

     4.1 传值调用

     4.2 传址调用

5. 函数的嵌套调用和链式访问

      5.1 嵌套调用

      5.2 链式访问

​6. 函数递归

      6.1 什么是递归?

      6.2 递归的两个必要条件

      6.2.1 练习

     


1. 函数是什么?

数学中我们常见到函数的概念。但是你了解C语言中的函数吗?

维基百科中对函数的定义子程序
         在计算机科学中,子程序,是一个大型程序中某部分代码由一个或多个语句块组
。它负责完成某项特定任务,而且相较于其他代 码,具备相对的独立性
         一般会有输入参数并有返回值,提供对过程的封装和细节的隐藏。这些代码通常被集成为
件库

2. C语言中函数的分类

   1. 库函数
   2. 自定义函数

2.1 库函数

为什么会有库函数?

    1. 我们知道在我们学习C语言编程的时候,总是在一个代码编写完成之后迫不及待的想知道结果,想把这个结果打印到我们的屏幕上看看。这个时候我们会频繁的使用一个功能:将信息按照一定的格式打印到屏幕上(printf)。
     2. 在编程的过程中我们会频繁的做一些字符串的拷贝工作(strcpy)。
     3. 在编程是我们也计算,总是会计算n的k次方这样的运算(pow)。
像上面我们描述的基础功能,它们不是业务性的代码。我们在开发的过程中每个程序员都可能用的到,为了支持可移植性和提高程序的效率,所以C语言的基础库中提供了一系列类似的库函数,方便程序员进行软件开发
注:
      库函数必须知道的一个秘密就是:使用库函数,必须包含 #include 对应的头文件

2.2 自定义函数

如果库函数能干所有的事情,那还要程序员干什么?
所有更加重要是自定义函数
自定义函数和库函数一样,有函数名返回值类型函数参数
但是不一样的是这些都是我们自己来设计。这给程序员一个很大的发挥空间

函数的组成:

我们举一个例子
            写一个函数可以找出两个整数中的最大值。



3. 函数的参数

3.1 实际参数(实参)

       真实传给函数的参数,叫实参。
       实参可以是:常量、变量、表达式、函数
       无论实参是何种类型的量,在进行函数调用时,它们都必须有确定的值,以便把这些值传送给形参。

3.2 形式参数(形参)

        形式参数是指函数名后括号中的变量,因为形式参数只有在函数被调用的过程中才实例化(分配内存单元),所以叫形式参数。形式参数当函数调用完成之后就自动销毁了。因此形式参数只在函数中有效


下面来分析一个例子:



       上面 Swap1 和 Swap2 函数中的参数 x,y,px,py 都是形式参数

       在main函数中传给 Swap1 的 num1 ,num2 和传给 Swap2 函数的 &num1 , &num2实际参数

这里我们对函数的实参和形参进行分析



      上面可以看出 Swap1 函数在调用的时候, x , y 拥有自己的空间同时拥有了和实参一模一样的内容
      所以我们可以简单的认为:形参实例化之后其实相当于实参的一份临时拷贝

4. 函数的调用

4.1 传值调用

 函数的形参和实参分别占有不同内存块,对形参的修改不会影响实参


4.2 传址调用

    1.传址调用是函数外部创建变量的内存地址传递给函数参数的一种调用函数的方式。
    2.这种传参方式可以让函数和函数外边的变量建立起真正的联系,也就是函数内部可以直接操
作函数外部的变量


5. 函数的嵌套调用和链式访问

      函数和函数之间可以根据实际的需求进行组合的,也就是互相调用的


5.1 嵌套调用

注:

       函数可以嵌套调用,但是不能嵌套定义


5.2 链式访问

把一个函数的返回值作为另外一个函数的参数




6. 函数递归

6.1 什么是递归?

 程序调用自身的编程技巧称为递归( recursion)。
 递归做为一种算法在程序设计语言中广泛应用。 一个过程或函数在其定义或说明中有直接或间接
 调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小问     题来求解,递归策略:只需少量的程序就可描述出解题过程所需要的多次重复计算大大地减少了程序的代码量

 递归的主要思考方式在于:把大事化小


6.2 递归的两个必要条件

1.存在限制条件,当满足这个限制条件的时候,递归便不再继续。
2.每次递归调用之后越来越接近这个限制条件


6.2.1 练习

    编写函数不允许创建临时变量,求字符串的长度

首先,我们先忽略不允许创建临时变量的条件,做法如下:

下面分析一下如何递归:

 最终代码如下:

函数,完结撒花!



     

  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
栈是一种后进先出(Last In First Out,LIFO)的数据结构,可以用来实现很多算法,其中一个就是栈的应用:十进制转八进制。 十进制转八进制的原理是将一个十进制数不断除以八,直到商为0,然后将每次的余数倒序排列起来即可得到八进制数。我们可以使用栈来实现这个过程。 具体的算法步骤如下: 1. 初始化一个栈,用来存放余数。 2. 对于给定的十进制数n,不断进行以下操作,直到商为0: 1) 将n除以8,将余数压入栈中。 2) 将n更新为商。 3. 从栈中依次弹出余数,得到的结果即为八进制数。 下面是使用C语言实现这个算法的代码示例: ```c #include <stdio.h> #define MAX_SIZE 100 int stack[MAX_SIZE]; int top = -1; void push(int x) { if (top == MAX_SIZE - 1) { printf("Stack overflow\n"); return; } stack[++top] = x; } int pop() { if (top == -1) { printf("Stack underflow\n"); return -1; } return stack[top--]; } void decimal_to_octal(int n) { while (n > 0) { push(n % 8); n /= 8; } while (top != -1) { printf("%d", pop()); } } int main() { int n; printf("Enter a decimal number: "); scanf("%d", &n); printf("Octal equivalent: "); decimal_to_octal(n); printf("\n"); return 0; } ``` 在这个程序中,我们使用了一个数组来实现栈的功能,其中`push`函数用来将元素压入栈中,`pop`函数用来从栈中弹出元素。在`decimal_to_octal`函数中,我们使用了栈来存储余数,然后在弹出的过程中得到八进制数。最后,在`main`函数中我们获取用户输入的十进制数并输出转换后的八进制数。 希望这个算法的详解对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值