1、
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<math.h>
//是素数返回1 不是返回0
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()
{
//打印100-200之间的素数
int i = 0;
for (i = 100; i <= 200; i++)
{
//判断i是否为素数
if (is_prime(i) == 1)
printf("%d ", i);
}
return 0;
}
2、
#define _CRT_SECURE_NO_WARNINGS 1
#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 year = 0;
for (year = 1000; year <= 2000; year++)
{
//判断year是否是闰年
if (is_leap_year(year) == 1)
printf("%d ", year);
}
return 0;
}
3、
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
//接收到的arr本质上是个指针
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 (arr[mid] < k)
{
left = mid + 1;
}
else if (arr[mid] > k)
{
right = mid - 1;
}
else
{
return mid;
}
}return -1;
}
int main()
{
//二分查找
//在一个有序的数组中查找具体的某个数字
//如果找到了,返回这个数字的下标 找不到返回-1
int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
int k = 7;
int sz = sizeof(arr) / sizeof((arr)[0]);
//arr传递的实际上是首元素的地址
int ret =binary_search(arr,k,sz);
if (ret == -1)
{
printf("找不到指定的数字\n");
}
else
{
printf("找到了他的下标是%d\n", ret);
}
return 0;
}
4、
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
void Add(int* p)
{
(*p)++;
}
int main()
{
int num = 0;
Add(&num);
printf("num=%d\n", num);//1
Add(&num);
printf("num=%d\n", num);//2
Add(&num);
printf("num=%d\n", num);//3
return 0;
}
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
int len = 0;
//1
len = strlen("abc");
printf("%d\n", len);
//2 和1相同
printf("%d\n", strlen("abc"));
return 0;
}
函数声明放在头文件里.h
函数定义放在单独函数定义文件.c
要用的时候直接Add就可以了