#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<math.h>
//判断一个数是不是素数
//判断一年是不是闰年
//实现一个整形有序数组的二分查找
//写一个函数,每调用一次这个函数。就会将num的值增加
int is_prime(int n)
{
int j = 0;
for (j = 2; j <=sqrt(n); j++)
{
if (n % j == 0)
return 0;
}
return 1;
}
int main()
{
int i = 0;
for (i = 100; i <= 200; i++)
{
if (is_prime(i) == 1)
{
printf("%d ", i);
}
}
return 0;
}
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<math.h>
//闰年
int is_leap_year(int m)
{
if (((m % 4 == 0) && (m % 100 != 0)) || m % 400 == 0)
return 1;
else
return 0;
}
int main()
{
int year = 0;
int num = 0;
for (year = 1000; year <= 2000; year++)
{
if (is_leap_year(year) == 1)
{
printf("%d ", year);
num++;
}
}
printf("%d", num);
return 0;
}
本质上arr是一个指针
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<math.h>
//二分查找
int binary_search(int arr[], int k,int sz)
{
int left = 0;
int right = sz - 1;
while (left <= right)
{
int mid = (left + right) / 2;
if (k > arr[mid])
{
left = mid+1;
}
else if (k < arr[mid])
{
right = mid-1;
}
else
{
return mid;
}
}
return -1;
}
int main()
{
//二分查找
int arr[] = { 1,2,3,4,5,6,7,8,9 };
int k = 17;
int sz = sizeof(arr) / sizeof(arr[0]);
int ret = binary_search(arr, k,sz);//传参只传首元素的地址
if (ret == -1)
{
printf("找不到指定数字\n");
}
else
{
printf("找到了,下标是%d\n", ret);
}
return 0;
}
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<math.h>
//写一个函数,每调用一次这个函数。就会将num的值增加
void Add(int* p)
{
(*p)++;
}
int main()
{
int num = 0;
Add(&num);
printf("num=%d\n", num);
Add(&num);
printf("num=%d\n", num);
Add(&num);
printf("num=%d\n", num);
return 0;
}
函数声明和定义
.h头文件存放函数声明
//函数声明
int Add(int x, int y);
.c文件存放函数定义
#define _CRT_SECURE_NO_WARNINGS 1
//函数的定义
int Add(int x, int y)
{
int z = x + y;
return z;
}
主程序文件引用头文件
#include<stdio.h>
#include"add.h"
int main()
{
int a = 10;
int b = 20;
int sum = 0;
sum = Add(a, b);
printf("%d\n", sum);
return 0;
}