1.定义函数,实现求两个double数字的最大值,并返回。
#include <stdio.h>
// 声明函数:算出两个数字中最大的数值
double max(double a, double b)
{
return a > b ? a : b;
}
int main()
{
// 调用次函数
double result = max(3.4, 6.9);
printf("最大数值:%lf", result);
printf("最大数值:%lf", max(1.2, 2.4));
return 0;
}
2.定义函数,求出三个int 类型数的和,并返回。
#include <stdio.h>
// 计算三个数字之和
int sum(int a, int b, int c)
{
return a + b + c;
}
int main()
{
int result = sum(1, 2, 3);
printf("%d\n",result);
return 0;
}
3.定义函数,判断一个数字是否是质数。
#include <stdio.h>
#include <stdbool.h>
// 封装一个函数:函数作用是判断这个数字是不是质数!
// 如果是质数,函数返回真
// 如果不是质数,函数返回假
bool Prime(int number)
{
// 统计能被整除的个数
int count = 2;
// 循环遍历
for (int i = 2; i < number; i++)
{
// 判断
if (number % i == 0)
{
count++;
break;
}
}
return count == 2 ? true : false;
}
int main()
{
int a;
// 提示
printf("请您输入一个大于1的整数:");
scanf("%d", &a);
// 接受函数返回的结果
bool isPrime = Prime(a);
if (isPrime)
{
printf("%d是质数", a);
}
else
{
printf("%d不是质数", a);
}
return 0;
}
4.函数可以没有返回值案例,编写一个函数,从终端输入一个整数打印出对应的金字塔,函数可以传入金字塔层数。
#include <stdio.h>
/**
*
* *
* *
*******
**/
void star(int row)
{
// 外层控制行数
for (int i = 1; i <= row; i++)
{
// 输出空格
for (int k = 1; k <= row - i; k++)
{
printf(" ");
}
// 输出星星
for (int j = 1; j <= 2 * i - 1; j++)
{
// 保留住每一行头部与尾部的星星
if (j == 1 || j == 2 * i - 1 || i == row)
{
printf("*");
}
else
{
printf(" ");
}
}
// 换行
printf("\n");
}
}
int main()
{
int line;
printf("请您输入楼层的层数:");
scanf("%d", &line);
star(line);
return 0;
}