前言🤞💕
在上一节课当中,我们简单学习了关于函数的分类、参数、调用的一些小知识,那么在这一节当中呢,我们就需要来做一些小练习来巩固我们的知识了。
一、写一个函数判断一个数是不是素数😎
#include<stdio.h>
#include <math.h>
//是素数返回1
//不是素数返回0
int is_prime(int i)
{
int j = 0;
for (j = 2; j <= sqrt(i); j++)
{
if (i % j == 0)
return 0;
}
return 1;
}
int main()
{
int i = 0;
int count = 0;
for (i = 100; i <= 200; i++)
{
//判断i是否为素数
if (1 == is_prime(i))
{
count++;
printf("%d ", i);
}
}
printf("\ncount = %d\n", count);
return 0;
}
二、写一个函数判断是不是闰年❤️
#include<stdio.h>
int is_leap_year(int y)
{
if (((y % 4 == 0) && (y % 100 != 0)) || (y % 400 == 0))
return 1;
else
return 0;
}
int main()
{
int y = 0;
for (y = 1000; y <= 2000; y++)
{
//判断y是否为闰年
//如果是闰年返回1
//不是闰年返回0
if (is_leap_year(y))
{
printf("%d ", y);
}
}
return 0;
}
三、写一个函数,实现一个整型数组的有序查找🤗
#include<stdio.h>
int binary_search(int arr[], int k , int sz)
{
int left = 0;
int right = sz - 1;
while (left<=right)
{
int mid = left + (right - left) / 2;
if (arr[mid] < k)
{
left = mid + 1;
}
else if (arr[mid] > k)
{
right = mid - 1;
}
else
{
return mid;
}
}
return -1;
}
int main()
{
int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
int k = 0;
scanf("%d", &k);
int sz = sizeof(arr) / sizeof(arr[0]);
//找到了就返回下标,找不到就返回-1
int ret = binary_search(arr, k, sz);
if (ret == -1)
printf("找不到\n");
else
printf("找到了,下标是:%d\n", ret);
return 0;
}
四、写一个函数,每调用一次这个函数,就会将 num 的值增加1✌️
#include<stdio.h>
void Add(int* p)
{
//*p = *p+1;
(*p)++;
}
int main()
{
int num = 0;
Add(&num);
printf("%d\n", num);
Add(&num);
printf("%d\n", num);
Add(&num);
printf("%d\n", num);
return 0;
}