189 8069 5689

【C语言】一些常用的函数-创新互联

目录

让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:申请域名、虚拟空间、营销软件、网站建设、河南网站维护、网站推广。

前言

这里都是以int类型为例,在使用时需要自己跟据实际情况更改数据类型。都比较简单,相信各位大佬们都能随便手打,但在写同一类型的题目时,多次的重复很容易影响刷题的爽感和连贯性,所以这里给出了一些刷题常用的功能。

冒泡排序

交换

幼稚小故事

逆转数组

幼稚小故事

打印整个数组(一维)

给一维数组赋值

打印整个二位数组

给二维数组赋值

求和函数

求差函数

求积函数

求商函数


前言 这里都是以int类型为例,在使用时需要自己跟据实际情况更改数据类型。都比较简单,相信各位大佬们都能随便手打,但在写同一类型的题目时,多次的重复很容易影响刷题的爽感和连贯性,所以这里给出了一些刷题常用的功能。 冒泡排序

传要排序的数组名,和元素个数。

顾名思义,冒泡一样的排序方法:较大\较小的值一个一个向后移动,直到遇到比它大的数或者到数组的边界。

我们这里用两个循环来完成,大循环决定有多少个数排序,小循环负责决定这个数接下来最多要比多少次。

​

void bubble_sort(int arr[], int n)
{
	int i = 0;int j = 0;int tmp = 0;
	for (i = 0; i< n; i++)
	{
		for (j = 0; j< n - 1-i; j++)
		{
			if (arr[j] >arr[j + 1])
			{
				tmp = arr[j + 1];
				arr[j + 1] = arr[j];
				arr[j] = tmp;
			}
		}
	}
}

​
交换

传要交换的两个数地址。

幼稚小故事

用倒酱油做例子,现在有两壶酱油,分别取名为A、B,A由精美的玻璃壶装,B由普通的塑料壶承装,但A酱油的品质比B酱油的差。

小乐乐想要送给朋友包装又好看,品质又好的酱油给朋友,就想让着两壶酱油交换瓶子。

一旁的小悲悲插话:“一定要倒掉一壶才能将B酱油倒进A酱油的瓶子。”

小乐乐想,他可不会干这种傻事,他要给小悲悲一点小小的乐乐震撼,于是他掏出了一个空瓶(上次小悲悲倒酱油的结果),先将A酱油倒入空瓶里,再将B酱油倒进A瓶里,最后将A酱油倒进B瓶子里。

这里,空瓶就是tmp,酱油A、B分别是*p2、*p1。

void swap(int* p1, int* p2)
{
	int tmp = 0;
	tmp = *p2;
	*p2 = *p1;
	*p1 = tmp;
}
逆转数组

传要逆转的数组以及数组元素个数。

幼稚小故事

小悲悲在编程时遇到一个问题(请将下列数组倒置,不允许用printf倒着打印)。

这下小悲悲可犯难了,于是爬上水管去找小乐乐解惑。

小乐乐听完,冷笑几声:“我看你是不懂哦~,我只需要n/2步就能搞定”,边说边拿出6个纸杯,成一长条摆在小悲悲前,“假如这是存放了六个元素的数组,我现在要将它倒置。”

小悲悲掏出笔记本记录。

小乐乐左手指着最左边的纸杯,右手指着最右边的纸杯,“假设我这两只手是指针,一个指向了数组的首元素,一个指向了数组的最后元素,我把这两个交换一下。”

小乐乐左手指向第二个纸杯,右手指向倒数第二个纸杯,“这是第二步,我把这两在交换一下。”

小乐乐左手指向第三个纸杯,右手指向倒数第三个纸杯,“这是第三步,我把这两再交换一下,看!是不是数组的元素倒过来了?”

小悲悲又问:“乐乐,你这是偶数个纸杯,要是是奇数个怎么办了?”

“中间那个单着的不需要换!”

“可是7/2是三点五次啊”

“INT类型的相除只取整数部分!”

void R_sto(int arr[],int sz)
{
	int* p1 = arr;
	int* p2 = &arr[sz - 1];
	int n = sz / 2;
	while (n)
	{
		int tmp = *p2;
		*p2 = *p1;
		*p1 = tmp;
		n--;
	}
}
打印整个数组(一维)

传要打印的数组名,传元素个数。

void P_arr(int arr[], int n)
{
	for (int i = 0; i< n; i++)
	{
		printf("%d", arr[i]);
	}
}
给一维数组赋值

传一维数组名,以及元素个数。

void AS_arr(int *p, int n)
{
	for (int i = 0; i< n; i++)
	{
		scanf("%d", (p + i));
	}
}

打印整个二位数组

传二维数组名,和行数、列数。

void P2_arr(int (*p) [N] ,int n,int m)
{
	for (int i = 0; i< n; i++)
	{
		for (int j = 0; j< m; j++)
		{
			printf("%d",*(*(p+i)+j));
		}
	}
}
给二维数组赋值

传二维数组数组名,行数,列数,N就是行数,需要自己填上去。

void AS2_arr(int(*p)[N], int n, int m)
{
	for (int i = 0; i< n; i++)
	{
		for (int j = 0; j< m; j++)
		{
			scanf("%d", (*(p + i) + j));
		}
	}
}
求和函数
int ADD(int m, int n)
{
	return m + n;
}
求差函数
int SUB(int m, int n)
{
	return m - n;
}
求积函数
int MUL(int m, int n)
{
	return m * n;
}
求商函数
int DIV(int m, int n)
{
	if (n != 0)
	{
		return m / n;
	}
	else
	{
		printf("除数不能为零!");
	}
}

你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧


名称栏目:【C语言】一些常用的函数-创新互联
网页网址:http://cdxtjz.cn/article/csspsp.html

其他资讯