蒙特卡羅c語言,蒙特卡洛c語言

本文目錄一覽:

C語言 用蒙特卡洛法求圓周率 幫忙修改一下程序

#includestdlib.h

#includetime.h

#includestdio.h

#define N 30000

int main() //標準C++寫法

{

double x,y; //不提倡用float,因為你已經顯式轉換成了double,會丟失數據.

int c=0,d=0;

srand((time_t)time(0)); //強制類型轉換

while(c++=N)

{x=rand()/(double)RAND_MAX;

y=rand()/(double)RAND_MAX;

if(x*x+y*y=1)

d++;

}

printf(“pi=%lf\n”,4.000000*d/N);

return 0; //返回值

}

c語言用蒙特卡洛方法求定積分 大佬幫忙看看哪裡不對

#includestdio.h

#include time.h

#include stdlib.h

double jifen(int, int, int, int);

int main()

{

    int a,b,d,n;

    double c;

    srand((unsigned)time(NULL));

    printf(“請輸入a b\n”);

    scanf(“%d %d”,a,b);

    printf(“請輸入n\n”);

    scanf(“%d”,n);

    d=1+b*b;

    c=jifen(a,b,d,n);

    printf(“積分為%lf\n”,c);

    return 0;

}

double jifen(int a,int b,int d,int n)

{

    int i,m=0;

    double x,y,result;

    for(i=1;i=n;i++){

        x=(double)rand()/(double)(RAND_MAX)*(b-a)+a;

        y=(double)rand()/(double)(RAND_MAX)*d;

        if(y=1+x*x) m++;

    }

    result=(double)m*(b-a)*d/n;

    return result;

};

如上 使用double 在最後加入result的強制轉換

另外在x定義那裡,改為(rand/rand_max)*(b-a)+a

因為是a,b 之間的距離隨機加a,當a不為0時原來的式子是錯的。

c語言,蒙特卡洛方法求pi。

dty@ubuntu:~$ cat pi.c

#includestdio.h

#includestdlib.h

#includetime.h

int main()

{

    unsigned long i;

    unsigned long m;

    const unsigned long N=100000000;

    double x,y,pi;

    srand((unsigned)time(NULL));

    for(i=0,m=0;iN;i++)

    {

        /*x,y在區間(-1,1)*/

        x=2.0*rand()/RAND_MAX-1;

        y=2.0*rand()/RAND_MAX-1;

        if((x*x+y*y)=1)

        { 

              m++;

        }

    }

    pi=4.0*m/N;

    printf(“%lf\n”,pi);

    return 0;

}

dty@ubuntu:~$ gcc pi.c

dty@ubuntu:~$ ./a.out 

3.141575

c語言中用蒙特卡洛法求積分輸出info00

#include “stdio.h”

#include “time.h”

#include “math.h”

#include “dos.h”

#define PI 3.1415926

main()

{ double x,y,sum=0;

int i;

for(i=0;i=100;i++)

{ srand(time(0));

x=rand()%10000;

x=x/10000*PI/2;

sleep(1);

srand(time(0));

y=rand()%10000;

y=y/10000;

if(y=sin(x)) sum++;

clrscr();

printf(“%d%”,i);

}

clrscr();

printf(“%f “,sum/–i);

}

TC上沒問題 VC上有點問題~~~~

原創文章,作者:FBBI,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/131037.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
FBBI的頭像FBBI
上一篇 2024-10-03 23:42
下一篇 2024-10-03 23:42

相關推薦

  • AES加密解密演算法的C語言實現

    AES(Advanced Encryption Standard)是一種對稱加密演算法,可用於對數據進行加密和解密。在本篇文章中,我們將介紹C語言中如何實現AES演算法,並對實現過程進…

    編程 2025-04-29
  • 學習Python對學習C語言有幫助嗎?

    Python和C語言是兩種非常受歡迎的編程語言,在程序開發中都扮演著非常重要的角色。那麼,學習Python對學習C語言有幫助嗎?答案是肯定的。在本文中,我們將從多個角度探討Pyth…

    編程 2025-04-29
  • Python被稱為膠水語言

    Python作為一種跨平台的解釋性高級語言,最大的特點是被稱為”膠水語言”。 一、簡單易學 Python的語法簡單易學,更加人性化,這使得它成為了初學者的入…

    編程 2025-04-29
  • OpenJudge答案1.6的C語言實現

    本文將從多個方面詳細闡述OpenJudge答案1.6在C語言中的實現方法,幫助初學者更好地學習和理解。 一、需求概述 OpenJudge答案1.6的要求是,輸入兩個整數a和b,輸出…

    編程 2025-04-29
  • Python按位運算符和C語言

    本文將從多個方面詳細闡述Python按位運算符和C語言的相關內容,並給出相應的代碼示例。 一、概述 Python是一種動態的、面向對象的編程語言,其按位運算符是用於按位操作的運算符…

    編程 2025-04-29
  • Python語言由荷蘭人為中心的全能編程開發工程師

    Python語言是一種高級語言,很多編程開發工程師都喜歡使用Python語言進行開發。Python語言的創始人是荷蘭人Guido van Rossum,他在1989年聖誕節期間開始…

    編程 2025-04-28
  • Python語言設計基礎第2版PDF

    Python語言設計基礎第2版PDF是一本介紹Python編程語言的經典教材。本篇文章將從多個方面對該教材進行詳細的闡述和介紹。 一、基礎知識 本教材中介紹了Python編程語言的…

    編程 2025-04-28
  • Python語言實現人名最多數統計

    本文將從幾個方面詳細介紹Python語言實現人名最多數統計的方法和應用。 一、Python實現人名最多數統計的基礎 1、首先,我們需要了解Python語言的一些基礎知識,如列表、字…

    編程 2025-04-28
  • Python作為中心語言,在編程中取代C語言的優勢和挑戰

    Python一直以其簡單易懂的語法和高效的編碼環境而著名。然而,它最近的發展趨勢表明Python的使用範圍已經從腳本語言擴展到了從Web應用到機器學習等廣泛的開發領域。與此同時,C…

    編程 2025-04-28
  • Python基礎語言

    Python作為一種高級編程語言擁有簡潔優雅的語法。在本文中,我們將從多個方面探究Python基礎語言的特點以及使用技巧。 一、數據類型 Python基礎數據類型包括整數、浮點數、…

    編程 2025-04-28

發表回復

登錄後才能評論