c语言输出n!的源代码
时间: 2023-04-05 13:03:20 浏览: 79
以下是C语言输出n!的源代码:
#include <stdio.h>
int main() {
int n, i;
long long factorial = 1;
printf("请输入一个正整数: ");
scanf("%d", &n);
// 如果输入的是负数,则输出错误信息
if (n < 0)
printf("错误!负数没有阶乘。");
else {
for (i = 1; i <= n; ++i) {
factorial *= i; // 阶乘计算
}
printf("%d 的阶乘为 %lld", n, factorial);
}
return 0;
}
相关问题
c语言求积分的源代码
以下是一个简单的C语言求积分的源代码示例,它使用梯形法则进行近似计算:
```c
#include <stdio.h>
double f(double x) {
// 这里假设函数在积分区间上是连续的,且在积分区间内只有一个极值点
return sin(x); // 替换为需要积分的函数
}
double integral(double a, double b, int n) {
double h = (b - a) / n;
double sum = 0.5 * (f(a) + f(b));
for (int i = 1; i < n; i++) {
double x = a + i * h;
sum += f(x);
}
return h * sum + 0.5 * (b + a) * h;
}
int main() {
double a = 0, b = 2 * M_PI; // 积分区间的起始和结束点
int n = 100; // 梯形的数量
double result = integral(a, b, n);
printf("积分结果为:%lf\n", result);
return 0;
}
```
这个代码使用了梯形法则来近似计算积分,它通过将积分区间分成n个相等的子区间,并使用梯形的面积来近似计算整个积分的面积。在代码中,我们首先定义了一个函数f(),它表示需要积分的函数。然后,我们定义了一个名为integral()的函数,它接受积分区间的起始和结束点以及梯形的数量n作为参数。在函数中,我们首先计算了每个子区间的宽度h,并使用梯形的面积公式来计算积分的近似值。最后,我们将结果返回给调用者。在主函数中,我们定义了积分区间的起始和结束点以及梯形的数量,并调用integral()函数来计算积分结果。最后,我们将结果输出到控制台。
需要注意的是,这个代码只是一个简单的示例,它假设函数在积分区间上是连续的,且在积分区间内只有一个极值点。在实际应用中,可能需要使用更复杂的算法来计算积分,例如数值微分和数值积分等。
c语言贪吃蛇小游戏源代码
当然,这是一个简单的C语言贪吃蛇小游戏的源代码示例:
```c
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#include <windows.h>
int width = 20, height = 20;
int gameover;
int x, y, fruitX, fruitY, score;
int tailX[100], tailY[100];
int nTail;
enum eDirection { STOP = 0, LEFT, RIGHT, UP, DOWN };
enum eDirection dir;
void Setup()
{
gameover = 0;
dir = STOP;
x = width / 2;
y = height / 2;
fruitX = rand() % width;
fruitY = rand() % height;
score = 0;
}
void Draw()
{
system("cls");
for (int i = 0; i < width + 2; i++)
printf("#");
printf("\n");
for (int i = 0; i < height; i++)
{
for (int j = 0; j < width; j++)
{
if (j == 0)
printf("#");
if (i == y && j == x)
printf("O");
else if (i == fruitY && j == fruitX)
printf("F");
else
{
int printTail = 0;
for (int k = 0; k < nTail; k++)
{
if (tailX[k] == j && tailY[k] == i)
{
printf("o");
printTail = 1;
}
}
if (!printTail)
printf(" ");
}
if (j == width - 1)
printf("#");
}
printf("\n");
}
for (int i = 0; i < width + 2; i++)
printf("#");
printf("\n");
printf("Score:%d\n", score);
}
void Input()
{
if (_kbhit())
{
switch (_getch())
{
case 'a':
dir = LEFT;
break;
case 'd':
dir = RIGHT;
break;
case 'w':
dir = UP;
break;
case 's':
dir = DOWN;
break;
case 'x':
gameover = 1;
break;
}
}
}
void Logic()
{
int prevX = tailX[0];
int prevY = tailY[0];
int prev2X, prev2Y;
tailX[0] = x;
tailY[0] = y;
for (int i = 1; i < nTail; i++)
{
prev2X = tailX[i];
prev2Y = tailY[i];
tailX[i] = prevX;
tailY[i] = prevY;
prevX = prev2X;
prevY = prev2Y;
}
switch (dir)
{
case LEFT:
x--;
break;
case RIGHT:
x++;
break;
case UP:
y--;
break;
case DOWN:
y++;
break;
default:
break;
}
if (x >= width)
x = 0;
else if (x < 0)
x = width - 1;
if (y >= height)
y = 0;
else if (y < 0)
y = height - 1;
for (int i = 0; i < nTail; i++)
{
if (tailX[i] == x && tailY[i] == y)
gameover = 1;
}
if (x == fruitX && y == fruitY)
{
score += 10;
fruitX = rand() % width;
fruitY = rand() % height;
nTail++;
}
}
int main()
{
Setup();
while (!gameover)
{
Draw();
Input();
Logic();
Sleep(10); // 控制游戏速度
}
return 0;
}
```
这个代码示例实现了一个基本的贪吃蛇小游戏,使用了C语言的基本语法和控制台输入输出函数。你可以将代码复制到一个C语言编译器中(如Dev-C++、Code::Blocks等)进行编译和运行。希望这能帮到你!