日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無先后,達(dá)者為師

網(wǎng)站首頁 編程語言 正文

C語言實(shí)現(xiàn)階乘的示例詳解_C 語言

作者:helinliupi-何 ? 更新時(shí)間: 2022-09-16 編程語言

前言

在現(xiàn)實(shí)中,我們做數(shù)學(xué)題總會(huì)遇到階乘問題,這在計(jì)算機(jī)中也不例外。 那我們應(yīng)該怎么實(shí)現(xiàn)呢?

我記得很多老師在電腦上書寫階乘都是用!這個(gè)符號(hào)表示。 比如5的階乘,寫為5!。 這在C語言中是行不通的,下面我講解C語言中階乘的實(shí)現(xiàn)。

1.階乘實(shí)現(xiàn)

1.1理論步驟

我們可以利用while、do……while、以及for等循環(huán)實(shí)現(xiàn),實(shí)現(xiàn)功能如下:

我們先設(shè)置好3個(gè)變量,i、n(想要的階層數(shù))、jieceng(階層結(jié)果)

利用循環(huán)得到相應(yīng)階乘

1.2實(shí)踐結(jié)果

這里用3種循環(huán)都展示一下

while實(shí)現(xiàn)

#include <stdio.h>
int main()
{
    int i = 1;
    int n = 0;
    int jieceng = 1;
    scanf("%d", &n);                      //輸入想得到的階層數(shù)
    while (i <= n)
    {
        jieceng *= i;
        i++;
    }
    printf("%d的階層是%d\n", n, jieceng);
    return 0;
}

do……while實(shí)現(xiàn)

#include <stdio.h>
int main()
{
    int i = 1;
    int n = 0;
    int jieceng = 1;
    scanf("%d", &n);
    do
    {
        jieceng *= i;
        i++;
 
    } while (i <= n);
    printf("%d的階層是%d\n", n, jieceng);
    return 0;
}

for實(shí)現(xiàn)

#include <stdio.h>
int main()
{
    int i = 1;
    int n = 0;
    int jieceng = 1;
    scanf("%d", &n);
    for (i = 1; i <= n; i++)
    {
        jieceng *= i;
    }
    printf("%d的階層是%d\n", n, jieceng);
    return 0;
}

2.連續(xù)乘層相加實(shí)現(xiàn)

2.1理論步驟

首先明確要連續(xù)相加,必然需要2層循環(huán)嵌套

2.2實(shí)踐結(jié)果

我這里用2層for循環(huán)實(shí)現(xiàn)

#include<stdio.h>
int main()                                         //算1~n階層相加
{
    int sum = 0;
    int jiecen = 0;
    int i = 0;
    int j = 0;
    int n = 0;
    scanf("%d", &n);                               //設(shè)置想要到達(dá)的n值
    for (j = 1; j <= n; j++)
    {
        for (i = 1, jiecen =1; i <= j; i++)         //重置jieceng,使每次從1開始
        {
            jiecen = jiecen * i;                   //里循環(huán)得每一相應(yīng)階層數(shù)
        }
        sum += jiecen;                             //階層之和
    }
    printf("%d\n", sum);
    return 0;
}

?一層for循環(huán)實(shí)現(xiàn)(簡(jiǎn)潔版)

#include <stdio.h>
int main()                                         //算1~10階層相加(j簡(jiǎn)短版)好**
{
    int sum = 0;
    int jiecen = 1;
    int i = 0;
    int n = 0;
    scanf("%d", &n);
    for (i = 1; i <= n; i++)
    {
        jiecen = jiecen * i;
        sum += jiecen;
    }
    printf("%d\n", sum);
    return 0;
}

原文鏈接:https://blog.csdn.net/helinliupi/article/details/125933669

欄目分類
最近更新