当前位置: 首页 > news >正文

c语言(初阶函数)完结

前言:

本篇内容对应

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;
}
 

相关文章:

  • 函数防抖和节流
  • AI 语言模型发展史:统计方法、RNN 与 Transformer 的技术演进
  • Spring Boot01(注解、)---java八股
  • 001-监控你的文件-FSWatch-C++开源库108杰
  • Typora导出word文件详细安装教程
  • 使用 Dify + DeepSeek 打造自己的本地知识库问答
  • 框架ThinkPHP(小迪网络安全笔记~
  • 计算机组成原理—— 外围设备(十三)
  • 配置Open-R1,评测第三方蒸馏模型的性能2
  • 2025百度快排技术分析:模拟点击与发包算法的背后原理
  • 一个简单的ubuntu/开发板初始化脚本
  • Redis 09章——哨兵(sentinel)
  • HTML元素
  • MATLAB中lookBehindBoundary函数用法
  • 滑动窗口——优先队列写法
  • 分享一个解梦 Chrome 扩展 —— 周公 AI 解梦
  • sql盲注脚本
  • 【数据结构入门 65 题】目录
  • 字符串(典型算法思想)—— OJ例题算法解析思路
  • Anaconda3 介绍和安装
  • 巴防空系统击落印度无人机,印称巴方违反停火协议
  • 上海劳模风采馆焕新升级后重新开放,展示480位劳模先进故事
  • 要更加冷静地看待“东升西降”的判断
  • 花2万多在海底捞办婚礼,连锁餐企要抢酒楼的婚宴生意?
  • 工行回应两售出金条疑似有杂质:情况不属实,疑似杂质应为金条售出后的外部附着物
  • 中俄弘扬正确二战史观:缅怀历史,重拾初心,阻止悲剧重演