cppreference.comhttps://zh.cppreference.com/w/%E9%A6%96%E9%A1%B5使用库函数,必须包含 #include 对应的头文件。
自定义函数和库函数一样,有函数名,返回值类型和函数参数。 但是不一样的是这些都是我们自己来设计。这给程序员一个很大的发挥空间。
ret_type fun_name(para1, *)
{
statement;//语句项
}
ret_type 返回类型
fun_name 函数名
para1 函数参数
#include
//写一个函数可以交换两个整形变量的内容。
//实现成函数,但是不能完成任务
void Swap1(int x, int y)
{
int tmp = 0;
tmp = x;
x = y;
y = tmp;
}
//正确的版本
void Swap2(int* px, int* py)
{
int tmp = 0;
tmp = *px;
*px = *py;
*py = tmp;
}
int main()
{
int num1 = 1;
int num2 = 2;
Swap1(num1, num2);
printf("Swap1::num1 = %d num2 = %d\n", num1, num2);
Swap2(&num1, &num2);
printf("Swap2::num1 = %d num2 = %d\n", num1, num2);
return 0;
}
形参实例化之后其实相当于实参的一份临时拷贝。
#include
//二分查找
int binary_search(int key, int arr[], int length) {
int left = 0, right = length - 1;
while (left <= right) {
int mid = (left + right) / 2;
if (arr[mid] < key) {
left = mid + 1;
}
else if (arr[mid] > key) {
right = mid - 1;
}
else {
return mid;
}
}
return -1;
}
int main() {
int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
int key = 7;
int length = sizeof(arr) / sizeof(arr[0]);
int res = binary_search(key,arr,length);
if (res==-1) {
printf("未找到\n");
}
else {
printf("找到了,为a[%d]\n", res);
}
return 0;
}
#include
void new_line()
{
printf("hehe\n");
}
void three_line()
{
int i = 0;
for (i = 0; i < 3; i++)
{
new_line();
}
}
int main()
{
three_line();
return 0;
}
函数可以嵌套调用,但是不能嵌套定义。
把一个函数的返回值作为另外一个函数的参数。
#include
#include
int main()
{
char arr[20] = "hello";
int ret = strlen(strcat(arr, "bit"));//这里介绍一下strlen函数
printf("%d\n", ret);
return 0;
}
#include
int main()
{
printf("%d", printf("%d", printf("%d", 43)));
//结果是啥?
//注:printf函数的返回值是打印在屏幕上字符的个数
return 0;
}
//test.h的内容
//放置函数的声明
#ifndef __TEST_H__
#define __TEST_H__
//函数的声明
int Add(int x, int y);
#endif //__TEST_H__
//test.c的内容
//放置函数的实现
#include "test.h"
//.lib 静态库
//导入静态库
#pragma comment (lib, "add.lib")
//函数Add的实现
int Add(int x, int y)
{
return x+y;
}
#include
//按照顺序打印它的每一位。
void print(unsigned int n) {
if (n > 9) {
print(n / 10);
}
printf("%d, ", n % 10);
}
int main() {
unsigned int num = 0;
scanf_s("%d", &num);
print(num);
return 0;
}
//求n的阶乘。(不考虑溢出)
int factorial(int n)
{
if(n <= 1)
return 1;
else
return n * factorial(n-1);
}
汉诺塔问题
1.借助c,把a上的n-1个盘子挪到b
2.把a上剩余的最后一个盘子直接挪到c