首页 > 其他分享 >函数的学习(三)

函数的学习(三)

时间:2024-08-07 20:23:32浏览次数:10  
标签:return 函数 递归 int 学习 add 定义

1.函数的声明和定义

在C语言中,函数的声明和定义是分开的。

函数的声明是指在程序中提前告诉编译器有一个函数存在,并且指定了函数的名称、参数类型和返回值类型。函数的声明一般放在头文件中,它的作用是告诉编译器有一个函数存在,并且在其他地方可能会用到这个函数。

函数的声明的语法形式为:返回值类型 函数名(参数列表);

例如,下面是一个简单的函数声明示例:

int add(int a, int b);

函数的定义是指给出函数的具体实现。函数的定义包含函数的返回值类型、函数名、参数列表和函数体。函数的定义一般放在C源文件中,它的作用是给出函数的具体实现。

函数的定义的语法形式为:返回值类型 函数名(参数列表) {函数体}

例如,下面是一个简单的函数定义示例:

int add(int a, int b) {
    int sum = a + b;
    return sum;
}

在上面的示例中,函数的定义中包含了函数体的具体实现,在函数体中定义了一个局部变量sum,计算a和b的和,并将结果返回。

需要注意的是,函数的声明和定义必须一致,即参数类型、返回值类型和参数个数必须相同。否则,在函数调用时会发生编译错误。

如果将函数声明和定义放在同一个源文件(.h)中,位置如下:

#include<stdio.h>
//函数声明
int add(int, int);

int main()
{
	int a = 10;
	int b = 20;
	int ret = add(a, b);
	printf("ret = %d\n", ret);
	return 0;
}

//函数定义
int add(int x, int y)
{
	return x + y;
}

但是如果将加法函数看作是一个模块的话,就可以将函数声明放入头文件add.h中,将函数定义放入源文件add.c中,在主函数需要用到加法模块时,需要引入加法的头文件#include"add.h"即可。

如下所示

#include<stdio.h>

#include"add.h"

int main()
{
	int a = 10;
	int b = 20;
	int ret = add(a, b);
	printf("ret = %d\n", ret);
	return 0;
}

2.函数的递归

在C语言中,函数的递归是指函数在其定义中调用自身的过程。通过函数的递归调用,函数可以多次重复执行相同的操作,直到满足某个终止条件。

函数的递归调用一般包括以下几个要素:

1)基本情况:定义递归函数时,需要确定一个或多个基本情况,即递归调用结束的条件。一旦满足基本情况,递归将停止,不再进行调用。

2)递归调用:在函数体内部,通过调用自身来实现递归。通常在每次递归调用时,问题的规模会减小。

3)递归结束条件:递归函数必须定义一个或多个结束条件,以确保递归不会无限循环调用自身。

递归函数的实现可以通过以下步骤进行:

(1)将问题分解为一个或多个较小的问题。

(2)在函数内部调用自身,解决较小的问题。

(3)当满足基本情况时,不再调用自身,返回结果。

下面是一个简单的例子,演示如何使用递归函数按照顺序打印一个整型值(无符号)数字的每一位,如输入1234,则输出1 2 3 4,具体实现代码如下:

#include<stdio.h>
void print(unsigned n)
{
	if (n > 9)
	{
		print(n / 10);
	}
	printf("%d ", n % 10);

}

int main()
{
	int  unsigned num = 0;
	scanf_s("%d", &num);
	print(num);//调用函数print()
	return 0;
}

在上面的例子中,函数printf通过递归调用自身来按顺序输出数字的每一位。当 n > 9时,递归停止。

例如输入数字1234,输出结果如下:

 接下来,再看一个例子:编写代码实现计算字符串的长度

方法一:直接使用strlen()函数

方法二:调用函数,代码如下:

#include<stdio.h>
#include<string.h>
int my_strlen(char* str)//数组传参传递的是数组的首地址,所以要写成指针的形式
{
	int count = 0;

	while (*str != '\0')//字符串存储是以'\0'结尾的,但是并不算字符串的长度
	{
		count++;
		str++;
	}
	return count;
}

int main()
{
	char arr[] = "abcdef";
	int len = my_strlen(arr);
	printf("%d\n", len);
	return 0;
}

 结果如下所示:

方法三:使用函数递归,代码如下:

#include<stdio.h>
#include<string.h>
int my_strlen(char* str)
{
	if (*str != '\0')
	{
		return 1 + my_strlen(str+1);
	}
	else
		return 0;
}

int main()
{
	char arr[] = "abcdef";
	int len = my_strlen(arr);
	printf("%d\n", len);
	return 0;
}

递归函数是一种强大的技术,可以用来解决多种复杂的问题。但需要注意的是,在使用递归函数时,必须确保递归能够终止,并且递归的层数不能太大,否则可能会导致栈溢出的问题。

标签:return,函数,递归,int,学习,add,定义
From: https://blog.csdn.net/NJL12138/article/details/140856813

相关文章

  • arduino相关函数
    I/O相关pinMode(pin,mode)作用:配置引脚以及引脚模式pin:为设置的引脚1,2,...mode:设置引脚的模式OUTPUT:输出模式INPUT:输入模式INPUT_PULLUP:上拉输入模式digitalWrite(pin,value)作用:配置引脚的值,设为高电平或低电平pin:设置的引脚value:HIGH或LOW设置为低......
  • FreeRTOS中任务创建函数xTaskCreate()的解析
    目录函数xTaskCreate()函数prvInitialiseNewTask()函数pxPortInitialiseStack()函数prvAddNewTaskToReadyList()总结函数xTaskCreate()此函数用于使用动态的方式创建任务,任务的任务控制块以及任务的栈空间所需的内存,均由FreeRTOS从FreeRTOS管理的堆中分配,若使用此函数,......
  • 19.python之自定义函数
    python之自定义函数一、函数的介绍1、函数定义:函数是一个组织好,可重复使用,实现单一或联合的代码段。2、函数作用:a、降低代码的冗余、b、增加代码的复用性c、提高程序的拓展性d、封装二、python的结构三、函数的使用1、格式:def函数名(变量):执行语句函数名(实际参数)#调......
  • js学习
    变量通过prompt收集输入信息声明变量特殊情况八股文字符类型可以随时变换js中数字前补0为八进制,补0x为十六进制方法:isNaN(),如果是数字返回false,反之返回true字符串转义符字符串与别的类型拼接,拼接后为字符串字符串内设置变量布尔值数据类型,true参与运算时作为1,f......
  • 音频应用编程-I.MX6U嵌入式Linux C应用编程学习笔记基于正点原子阿尔法开发板
    音频应用编程Linux下ALSA框架概述ALSA简介:ALSA是AdvancedLinuxSoundArchitecture(高级的Linux声音体系)的缩写地位与功能:现已成为Linux下的主流音频体系架构,提供音频和MIDI支持,替代了旧版本中的OSS(开放声音系统)框架设计:ALSA是Linux系统下标准且先进的......
  • OVER (PARTITION BY xx ORDER BY xx) 窗口函数理解
    SUM(sale_amount)OVER(PARTITIONBYsalespersonORDERBYsale_date)这段SQL窗口函数的详细解释和它在执行过程中所发生的具体细节如下:解析步骤窗口函数的基础定义:SUM(sale_amount):表示我们要对sale_amount列应用SUM聚合函数。OVER子句:指定窗口函数的范围和计算......
  • 英语真题在线解决查词限制次数(仅供学习参考)
    在我学习四级的时候发现了一个在线四六级题库网站,而且还自带翻译功能,实在是太贴心了。网站地址如下:英语真题在线-试卷排版设计|官网(burningvocabulary.cn)但是它每天查词次数有限  所以我想看看能不能让我多查几次,然后我觉着它不可能联网记录我的查询次数,那么肯定在......
  • Visionpro二次开发学习笔记7-使用CogToolDisplay控件
    CogToolDisplay控件可显示与视觉工具记录相关的图像,图形和其他状态信息。它使用CogRecord和ICogTool接口将图像和图形连接到CogDisplay。图片清单控件的CogComboBox列出当前记录及其子记录中的图像和图形。您可以单击列表并选择要显示的图像或图形。如果记录层次结构仅包......
  • 内存重叠以及memcpy和memmove函数详解
    内存重叠当我们进行内存拷贝(memcpy函数)时或者在自己实现内存拷贝函数strcpy时,如果存在目标地址在原地址的范围内就造成了内存重叠。一开始看到这个名词的时候,确实有点难以理解,经过学习,我利用以下的例子来说明内存重叠问题。首先,先介绍一下memcpy和memmove函数memcpy和mem......
  • 四、神经网络(深度学习算法)
    4.1认识神经网络必要性当特征值只有两个时,我们仍可以用之前学过的算法去解决但当特征值很多,且含有很多个多次多项式时,用之前的算法就很难解决了例子:图像感知Recogonitionimage计算机识别汽车是靠像素点的亮度值  神经网络做法:4.2如何在神经网络上推理4.2.1......