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