c语言-函数

13 篇文章 0 订阅
12 篇文章 0 订阅

函数

c语言常用的库函数:

  • IO函数
  • 字符串操作函数
  • 内存操作函数
  • 时间/日期函数
  • 数学函数
  • 其他库函数

strcpy函数

  • 这个函数的目的是拷贝内容,使用的时候还需要引用头文件#include<string.h>

memset函数----memory–内存–set–设置

在这里插入图片描述

为什么要有函数???

  • 函数的基本组成:
  • ret_type fun_name(para1,*)
  • {
  • statement; //语句项
  • }
  • ret_type 返回类型
  • fun_name 函数名
  • para1 函数参数
  • 举个例子
写一个函数找两个整数的较大值在这里插入图片描述
写一个函数交换两个数
  • 这个代码是不能交换的;原因:是因为这它们各自的存储空间是不一样的,即使x,y交换的;但是a,b的值是不会改变的,它们都有各自的空间,没有一点关系
  • 结论:当实参传给形参的时候,形参其实是实参的一份临时拷贝,对形参的修改不会改变实参的
    在这里插入图片描述
改进
  • 接下来就是要让它们的地址有关系,那么就要用到指针,开辟空间来接收a,b的值
实际参数
  • 真实传给函数的参数,叫实参。实参可以是:常量,变量,表达式,函数等。无论实参是何种类型的量,在进行函数调用时,它们必须有确定的值,以便把这些值传送给实参
形式参数
  • 形式参数就是指函数名后括号中的变量,因为形式参数只有在函数被调用的时候才实例化(分配内存单元),所以叫形式参数。形式参数当函数调用完成之后就自动销毁,因此形式参数只在函数中有效

函数的调用

传值调用
  • 函数的形参和实参分别占有不同的内存块,对形参的修改不会影响实参
传址调用
  • 传址调用是把函数外部创建的变量的内存地址传递给函数参数的一种调用方法
  • 这种传参方式可以让函数和函数外边的变量建立起真正的联系,也就是函数内部可以直接操作函数外部的变量
写一个函数判断是否为素数

在这里插入图片描述

写一个函数判断是否为闰年

在这里插入图片描述

用函数在有序数组查找某个元素(二分查找法)

在这里插入图片描述

写一个函数,每调用一次这个函数,就会将num的值增加1

在这里插入图片描述

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

在这里插入图片描述

链式访问
  • 把一个函数的返回值作为另外一个函数的参数
    在这里插入图片描述
  • 原因:printf打印的为字符串长度
函数的声明和定义

在这里插入图片描述

  • 函数的声明的主要目的并不是多此一举把函数的定义放在后面
  • 主要目的:为啦团队在做一个项目时,可以将项目更好的分工
    在这里插入图片描述
  • 在这里插入图片描述
  • .c中写函数
  • 在这里插入图片描述
  • .h中写头文件

函数的递归

什么是递归???
  • 程序调用自身的编程技巧称为递归。递归作为一种算法在程序设计语言中广泛应用。一个过程或一个函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可以描述出解题过程所需要的重复计算,大大减少了程序的代码量。
  • 主要思考方式:把大事化小
递归的两个必要条件
  • 存在限制条件,当满足这个限制条件的时候,递归便不再继续
  • 每次递归调用后会越来越接近这个限制条件
接受一个整型值(无符号),按照顺序打印它的每一位。eg:输入:1234,输出:1 2 3 4

在这里插入图片描述

  • 别看它代码只有几行,但是它内部的计算是比较麻烦的
编写一个代码不允许创建临时变量,求字符串的长度
  • 以下创建啦临时变量
    在这里插入图片描述

用递归方法,求字符串长度

在这里插入图片描述

用计数器求字符串长度

在这里插入图片描述

递归和迭代
求n的阶乘(不考虑溢出)
  • 最简单的方法
  • 在这里插入图片描述
  • 用循环
  • 在这里插入图片描述
  • 用递归
  • 在这里插入图片描述
求第n个斐波那契数
  • 这个代码比较麻烦,做了许多重复的工作
    在这里插入图片描述
  • 测试第30个斐波那契数
  • 计算了832039次在这里插入图片描述
优化斐波那契数

1 1 2 3 5 8 13 21 34
a b c
a b c 从左向右移动

在这里插入图片描述

汉诺塔问题

青蛙跳台问题

  • 青蛙可以一次跳一个台阶
  • 也可以跳2个台阶
  • 问青蛙跳到第n个台阶,有多少种方法
    在这里插入图片描述
  • 法二
  • 效率高
    在这里插入图片描述
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值