c语言(初阶函数)完结
- 互联网
- 2025-09-08 12:03:01

前言:
本篇内容对应
40. 【C语言初阶】函数_哔哩哔哩_bilibili 40集
这里主要是自建函数的写法
然后这一集主要讲的是自己写的交换函数,但是之前明明记得是老师在讲内置函数的运用啊,怎么突然讲到自建函数了,好奇怪,算了,不管了,先写这个吧
题目,就是交换两个变量的值(写一个函数)嗯就是说自建了一个Swap函数,然后来交换两个变量的值,这个是错的,然后题目好像就要求写一个错的函数
这里主要是将形参和实参的区别
形参,就是自建函数,没有调用就不占空间,调用了,然后存的值,他的值只是临时存档的,
实参,实际存在,在主函数里面,在他的作用域有效
然后这里的int x,int y其实就是临时存a,b的值,并不直接参与a和b的调换,就算是将这里的int x,int y改成int a,int b也是一样的,这只能说函数名冲突了,然后他们两个地址是不一样的,所以这里变了,和a,b没有关系
#include <stdio.h> void Swap(int x,int y) { int z = 0; z = x; x = y; y = z; } int main() { int a = 0; int b =0; scanf("%d %d", &a, &b); //交换前 printf("交换前a和b的值a=%d,b=%d \n", a, b); //交换后 Swap(a,b); printf("交换后a和b的值a=%d,b=%d \n", a, b); return 0; }然后就是正确的做法是,将指针参与进来,因为指针就是地址的意思,那如果我直接将a地址的内容和b地址的内容调换了,那a和b的值就互换了
注意,这里变的是a,b的值,然后他们本身的地址是不能改变的
int a = 0;
a = 10; //直接改a的值
int *p = &a;
*p = 30; //间接改a的值,通过地址改a的值
*p指向的是a的地址的内容,但是改的话只是改空间里的内容,地址不能更改
int z = 0; z = *px; //也就是将a的值传给z *px = *py; //b的值传给a *py = z; //a的值传给b
#include <stdio.h> void Swap(int *px,int *py) { int z = 0; z = *px; //也就是将a的值传给z *px = *py; //b的值传给a *py = z; //a的值传给b } int main() { int a = 0; int b =0; scanf("%d %d", &a, &b); //交换前 printf("交换前a和b的值a=%d,b=%d \n", a, b); //交换后 Swap(&a,&b); printf("交换后a和b的值a=%d,b=%d \n", a, b); return 0; }错误的写法
void Swap(int *px,int *py) { int z = 0; z = px; //这样的话只是将a的地址传给z了 px = py; //b的地址传给px了,这里都没有参与到a,因为px和a没有直接的关系了,不是指针了 py = z; //a的地址传给py }
这的我想了挺久的,因为我想的是px的这个地址传给了int *px,就是传给上面的大括号里面了,但是我后面想了一下,程序是从上往下执行的,不会在传上去了,况且这里也是无返回值
就算传上去了,那不是把a的地址当做值给b了,???不可能
题目,选出100~200的素数看了一下午,
什么是素数,就是不能被1和他本身的数整除,
写代码的思路
嗯先定义一个循环,就是我们需要去判断100~200之间的素数,
然后就是如何去找出素数,就是需要看是否除了1和本身,还有有没有其他数能够整除这个数
然后就是判断如果都不能整除,就返回是素数,否则返回不是素数
代码
int main() { int i = 0; for(i=100; i<=200; i++) { int r = 2; int flag = 1; //假如是素数 for(r = 2; r < i-1; r++) if(i % r == 0) { flag = 0; break; } if(flag == 1) { printf("%d ", i); } } return 0; }那这个用自定义函数该怎么用呢
首先,这个定义一个函数,这个函数需要去传参,需要将100~200的值传给这个函数
然后就是函数有返回值,就不能用void无返回值
主要是
需要判断这个函数需要实现上面样的功能,比如这里就
需要实现寻找素数,找到了就返回结果,然后在主函数打印
这里需要注意的是return 0; 这个实际上的意思是返回一个0;
需要注意的是需要等循环结束了,还没有找到被整除才返回1,不要在循环里返回结果
int is_prime(int n) { int r = 2; for(r = 2; r < n-1; r++) { if(n % r == 0) { return 0; } } return 1; }实现了基本是代码逻辑,那如何优化代码捏
嗯,有一个函数可以开平方(sqrt()函数,这个需要一个头文件是,<math.h>)
例如一个不是素数的值
根号16=4 4*4=16
2*8=16
就是不是素数的,他总会有一个数,小于他的平方根4(我也不晓得,我就记结论了)
就是这样的,这个不用担心开平方不是一个整数,只需要约等于就好了,就像101,近似等于10,至于为啥,我也不知道
for(r = 2; r < sqrt(n); r++) { if(n % r == 0) { return 0; } }然后偶数也不可能是素数,所以也可以这样改
从101开始,然后每次+2
for(i=101; i<=200; i+=2) { if(get_add(i)) { printf("%d ", i); count ++; } }实现代码
#include <stdio.h> #include <math.h> int get_add(int n) { int r = 2; for(r = 2; r < sqrt(n); r++) { if(n % r == 0) { return 0; } } return 1; } int main() { int i = 0; int count = 0; for(i=101; i<=200; i+=2) { if(get_add(i)) { printf("%d ", i); count ++; } } printf("\ncount = %d\n", count); return 0; }c语言(初阶函数)完结由讯客互联互联网栏目发布,感谢您对讯客互联的认可,以及对我们原创作品以及文章的青睐,非常欢迎各位朋友分享到个人网站或者朋友圈,但转载请说明文章出处“c语言(初阶函数)完结”