本节内容主要记录函数的相关内容,其中包括:库函数,自定义函数,函数的调用,函数的习题练习。
(在上节的循环语句中加入了 goto语句,有兴趣的朋友们可以去了解了解,有一个小整蛊哦。)
循环语句链接:
[ C语言 ]循环语句---while---for---do while---详解及练习题巩固_小白又菜的博客-CSDN博客
本篇文章开始之前,首先感谢大家的关注和支持,让我人生首次在一件事情上粉丝破千!!!(真的想象不到)
其实我开始写博客的初衷是记录自己的学习过程,通过写博客的方式对知识进行再次总结,加深自己对知识的记忆,我现在的目的如此,以后仍然是!每每看到关注量,浏览量这些数据增加,都会让我变得开心,这是大家给予我的一份肯定。在此,感谢各位一直以来的支持,我以后也会对自己的知识记录更加详细,更加丰富,在记录我进步的同时,希望大家通过看到我的博客也会进步。我们一起朝着自己的大厂梦前进吧!!!
话不多说,上车!!!
——————————————————————————————————————————— ****正文开始****
Q : 为什么会有库函数?
A :
1. 我们知道在我们学习C语言编程的时候,总是在一个代码编写完成之后迫不及待的想知道结果,想把这个结果打印到我们的屏幕上看看。这个时候我们会频繁的使用一个功能:将信息按照一定的格式打印到屏幕上(printf)。
2. 在编程的过程中我们会频繁的做一些字符串的拷贝工作(strcpy)。
代码:
#include
#include
int main() {
char arr[] = "abc";
// size_t -> unsigned int
size_t len = strlen(arr);
printf("%u\n", len);
// %d - 有符号
// %u - 无符号 (没有负数)
return 0;
}
代码演示:
#include
#include
int main() {
char arr1[20] = { 0 };// 目的地
char arr2[] = "hello" ;// 源数据
strcpy(arr1, arr2);
printf("%s\n",arr1);
return 0;
}
结果:
我们发现本来是空的arr1中拷贝了arr2中的"hello"
代码演示:
#include
#include
int main(){
char arr[] = "hello world";
memset(arr, 'x', 5);
printf("%s\n", arr);
return 0;
}
演示结果:
//***自定义函数***
// 函数返回类型 函数名 参数
// ret_type fun_name(para1,*)
// { //
// statement; // 语句项 //函数体
// } //
ret_type 返回类型
fun_name 函数名
para1 函数参数
代码:
// 写一个函数,找出两个数的最大值
//返回类型 函数名 参数
int get_max(int x, int y) {
int z = 0;
z = (x > y ? x : y);
return z;
}
int main() {
int a = 0;
int b = 0;
scanf("%d %d", &a, &b);
int m = get_max(a, b);
printf("%d\n", m);
return 0;
}
演示结果:
按照我们正常的书写代码如下:
void Swap1(int x, int y) {
int temp = 0;
temp = x;
x = y;
y = temp;
}
int main() {
int a = 0, b = 0;
scanf("%d %d", &a, &b);
// 交换两个变量
printf("交换前a = %d, b = %d\n", a, b);
Swap1(a,b); // 传值调用
printf("交换后a = %d, b = %d\n", a, b);
return 0;
}
正确的写法:
正确写法 使用指针
void Swap2(int* pa,int* pb) {
int t = 0;
t = *pa;
*pa = *pb;
*pb = t;
}
int main() {
int a = 0, b = 0;
scanf("%d %d", &a, &b);
// 交换两个变量
printf("交换前a = %d, b = %d\n", a, b);
Swap2(&a,&b); // 传址调用
printf("交换后a = %d, b = %d\n", a, b);
return 0;
}
结果演示:
我们观察这段代码发现,a和b并没有交换。
失败的原因是:a 和 b 是实参 , x 和 y 是形参。当函数调用的时候,实参传给形参,形参其实是实参的一份临时拷贝。所以对形参的修改,不会影响实参。
代码对应的内存分配如下:
一:写一个函数可以判断一个数字 是不是素数
//is_prime()
//是素数返回 1 ,不是素数返回 0
int is_prime(int n) {
// 2 ~ n-1 的数字试除
int j = 0;
for (j = 2; j <= sqrt(n); j++) {
if (n % j == 0) {
return 0;
}
}
return 1;
}
int main() {
int i = 0;
for (i = 100; i <= 200; i++) {
// 判断 i 是否为素数 - 如果是素数就打印
// i 取 100 - 200
if (is_prime(i) == 1) {
printf("%d ", i);
}
}
return 0;
}
演示结果:
二:写一个函数判断一年是不是闰年
//写一个函数判断一年是不是闰年
//是闰年 返回1 不是闰年 返回0
int is_leap_year(int y) {
//if (y % 100 != 0 && y % 4 == 0 || y % 400 == 0) {
// return 1;
//}
//else {
// return 0;
//}
return (y % 100 != 0 && y % 4 == 0 || y % 400 == 0);
}
int main() {
int y = 0;
for (y = 1000; y <= 2000; y++) {
// 判断 y 是不是闰年
if (is_leap_year(y) == 1) {
printf("%d ",y);
}
}
return 0;
}
代码演示结果:
三: 写一个函数 ,实现一个整形有序数组的二分查找
//写一个函数 ,实现一个整形有序数组的二分查找
//如果找到了返回 下标
//如果找不到返回 -1
int binary_search(int arr[], int k,int sz) {
int left = 0;
int right = sz - 1;
while (left<=right) {
int mid = (left + right) / 2;
if (arr[mid] < k) {
left = mid + 1;
}
else if (arr[mid] > k)
{
right = mid - 1;
}
else if (left == right) {
return mid;
}
}
return -1;
}
int main() {
int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
int k = 7;
int sz = sizeof(arr) / sizeof arr[0];
// 40 / 4
// 数组arr传给binary_search函数的时候,其实传递的arr数组首元素的地址
int ret = binary_search(arr,k,sz); // 在arr数组中找k
if (-1 == ret) {
printf("找不到\n");
}
else {
printf("找到了,下标是%d\n", ret);
}
return 0;
}
代码演示结果:
四:实现一个函数,打印乘法口诀表,口诀表的行数和列数自己指定
如:输入9,输出9 * 9口诀表,输出12,输出12 * 12的乘法口诀表。
void Multiplication_formula_table(int i, int j,int n) {
for (i = 1; i <= n; i++) {
for (j = 1; j <= i; j++) {
printf("%d*%d=%d ", j, i, i* j);
}
printf("\n");
}
}
int main() {
int n = 0;
scanf("%d",&n);
int i = 0;
int j = 0;
Multiplication_formula_table(i ,j,n);
return 0;
}
结果演示:
****正文结束****
——————————————————————————————————————————
本篇文章的内容就记录完毕,由于本人技术水平有限,若各位读者发现错误,欢迎及时纠正。