C语言远征之基础篇

c语言远征第7天

学习了函数后,准备将之前的作业都写成函数的形式,再补充一个简单冒泡排序法

1.冒泡排序法

#include <stdio.h>
#include <stdlib.h>

void Swap(int *x, int *y)
{
	int tmp = *x;
	*x = *y;
	*y = tmp;
}
void Bubble_Ser(int arr[],int size)
{
	//定义一个边界,已经排过序的放入bound内,未排序的任然在size内,
	//起始时刻bound内的数为0,最大的数冒泡到数组顶部,bound+1;
	//再将剩余的size-bound个数进行排序,指导次大值冒泡上来,放入bound
	//以此类推,所有数进入bound,完成排序。
	for (int bound = 0; bound <= size; ++bound)
	{
		for (int i= 0; i < (size-bound); ++i)
		{
			if (arr[i] > arr[i + 1])
			{
				//int tmp = arr[i];
				//arr[i] = arr[i + 1];
				//arr[i + 1] = tmp;
				Swap(&arr[i], &arr[i + 1]);
			}
		}
	}
}
int main()
{
	//冒泡排序法
	int arr1[] = { 2,9,5,3,8,0,6 };
	int size = sizeof(arr1) / sizeof(arr1[0]) - 1;
	Bubble_Ser(arr1, size);
	for (int j = 0; j <= size; ++j)
	{
		printf("%d", arr1[j]);
	}
	system("pause");
	return 0;
}

2.实现一个函数,打印乘法口诀表,口诀表的行数和列数自己指定, 输入9,输出99口诀表,输入12,输出1212的乘法口诀表。

//乘法表函数
void Multiplication(int row)
{
	for (int i = 1; i <= row; ++i)
	{
		for (int j = 1; j <= i; ++j)
		{
			printf("%d * %d = %d ", i, j, i *j);
		}
		printf("\n");
	}
}

3.实现一个函数判断year是不是闰年。

//判断闰年函数
void Judge_Runyear(int year)
{
	if ((year % 4 == 0)&&(year % 100 != 0)||(year % 400 == 0))
	{
		printf("是闰年\n");
	}
}

4.创建一个数组, 实现函数init()初始化数组、 实现empty()清空数组、 实现reverse()函数完成数组元素的逆置。

#define MAX_ROW 6
#define MAX_COL 6

char arr1[MAX_ROW][MAX_COL];
int arr2[MAX_ROW] = {1,2,3,4,5,6};
void init()
{
	int row = 0;
	int col = 0;
	for (; row <= MAX_ROW; ++row)
	{
		for (; col <= MAX_COL; ++col)
		{
			arr1[row][col] = 0;
		}
	}
}
void empty()
{
	int row = 0;
	int col = 0;
	for (; row <= MAX_ROW; ++row)
	{
		for (; col <= MAX_COL; ++col)
		{
			arr1[row][col] = ' ';
		}
	}
}
void reverse(int arr[])
{
	int row = 0;
	int col = 0;
	for (; row <= MAX_ROW/2; ++row)
	{
		Swap(&arr[row], &arr[(MAX_ROW - row - 1)]);
	}
}
int main()
{
    reverse(arr2);
	for (int i = 0; i <= (MAX_ROW - 1); ++i)
	{
		printf("%d\n",arr2[i]);
	}
	system("pause");
	return 0;
}

5.实现一个函数,判断一个数是不是素数。

void Judge_Prime(int num)
{
	if ((num == 1) || (num == 0))
	{
		printf("不是素数\n");
	}
	else {
		int i = 2;
		int flag = 0;
		for (; i < num; ++i)
		{
			if (num % i == 0)
			{
				flag = 1;
				break;
			}
		}
		if (flag == 1)
		{
			printf("不是素数\n");
		}
		else
		{
			printf("是素数\n");
		}
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值