24小时热门版块排行榜    

查看: 1104  |  回复: 6
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

836449366

金虫 (小有名气)

[求助] 计算圆周率的小程序出错 已有1人参与

我的程序是计算圆周率,原理是:在一个1*1的正方形及其内切圆(圆心为(0.5,0.5))中,随机数x和随机数y组成的点位于正方形内,但要判断这个点是否也在圆内,当点数很多时,圆内的点数除以总数再乘以4就等于圆周率了(即面积之比),我所编写的程序如下:
program main
      implicit none
      integer*4 :: i,j,n,ii
      common i
      real*4 :: r
       call random_number(x)
       call random_number(y)
       real*4,dimension(i):: x,y
       r=sqrt((x-0.5)**2+(y-0.5)**2)
       ii=0
      do n=2,8,1
       i=10**n
       do j=1,i
       if ( r .le. 0.5 )   then
         ii=ii+1
       endif
      enddo
      enddo
      write(*,"(a,3F6.3)" "pai=",4*ii/i,x,y
      end
求虫友帮帮忙,谢谢
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

836449366

金虫 (小有名气)

引用回帖:
4楼: Originally posted by fish.yfyh at 2013-12-13 11:21:49
因为num是整数呀,E10.2是科学计数法的浮点数,所以这样就可以了。
write(*,"(a,F6.3,E10.2)" ) "pai=",4.0*ii/num,num*1.0...

非常感谢你的回答
5楼2013-12-13 15:06:17
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 7 个回答

fish.yfyh

铜虫 (小有名气)

【答案】应助回帖

感谢参与,应助指数 +1
感觉你代码的错误蛮多,然后我改写了一下。
      program main
      implicit none
      integer*4 :: num,i,j,ii
      real*4 :: r
      real*4,allocatable :: x(,y(
      
      num = 100000
      allocate(x(num))
      allocate(y(num))
      call random_seed()
      call random_number(x)
      call random_number(y)
      
      ii = 0
      do i = 1,num
          r = sqrt((x(i)-0.5)**2 + (y(i)-0.5)**2)
          if(r .le. 0.5) then
              ii = ii+1
          end if
      end do
      
      write(*,"(a,F6.3)" "pai=",4.0*ii/num
      
      deallocate(x,y)
      
      stop
      end program

» 本帖已获得的红花(最新10朵)

2楼2013-12-12 20:30:56
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

836449366

金虫 (小有名气)

送红花一朵
引用回帖:
2楼: Originally posted by fish.yfyh at 2013-12-12 20:30:56
感觉你代码的错误蛮多,然后我改写了一下。
      program main
      implicit none
      integer*4 :: num,i,j,ii
      real*4 :: r
      real*4,allocatable :: x(,y(
      
      num = 100000
...

非常感谢你的回答,运行也正确,但当我在write后加一个一个变量输出时,改为
” write(*,"(a,F6.3,E10.2)" "pai=",4.0*ii/num,num “,
这样输出的结果为
" pai= 3.141  0.14E-39 "
这样的输出的结果是错误的,num输出的值应为1.00E+05
问题出在哪?求虫友再次解惑下?
我的目的是做个循环,看看输入的值越大,得到的圆周率的结果越准确。
3楼2013-12-13 11:05:12
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

fish.yfyh

铜虫 (小有名气)

【答案】应助回帖

★ ★ ★ ★ ★
836449366: 金币+5, ★★★★★最佳答案, 非常感谢 2013-12-13 15:05:24
引用回帖:
3楼: Originally posted by 836449366 at 2013-12-13 11:05:12
非常感谢你的回答,运行也正确,但当我在write后加一个一个变量输出时,改为
” write(*,"(a,F6.3,E10.2)" "pai=",4.0*ii/num,num “,
这样输出的结果为
" pai= 3.141  0.14E-39 &q ...

因为num是整数呀,E10.2是科学计数法的浮点数,所以这样就可以了。
write(*,"(a,F6.3,E10.2)" ) "pai=",4.0*ii/num,num*1.0
4楼2013-12-13 11:21:49
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 085601材料工程专硕求调剂 +7 慕寒mio 2026-03-16 7/350 2026-03-19 10:57 by w沐阳w
[考研] 321求调剂 +6 何润采123 2026-03-18 6/300 2026-03-19 10:55 by daliangogo
[考研] 材料080500调剂求收留 +4 一颗meteor 2026-03-13 4/200 2026-03-19 10:32 by 30660438
[考研] 274求调剂 +6 S.H1 2026-03-18 6/300 2026-03-19 09:34 by 花店相见
[考研] 本科郑州大学物理学院,一志愿华科070200学硕,346求调剂 +4 我不是一根葱 2026-03-18 4/200 2026-03-19 09:11 by 浮云166
[考研] 085600材料与化工调剂 324分 +9 llllkkkhh 2026-03-18 9/450 2026-03-19 07:40 by BruceLiu320
[考研] 一志愿天津大学化学工艺专业(081702)315分求调剂 +10 yangfz 2026-03-17 10/500 2026-03-18 20:14 by walc
[考研] 085600材料与化工 +5 安全上岸! 2026-03-16 5/250 2026-03-18 15:33 by cmz0325
[考研] 0703化学调剂 ,六级已过,有科研经历 +10 曦熙兮 2026-03-15 10/500 2026-03-18 14:19 by 007_lilei
[考研] 0703化学调剂 +4 pupcoco 2026-03-17 7/350 2026-03-18 12:14 by djl2006
[考研] 277调剂 +5 自由煎饼果子 2026-03-16 6/300 2026-03-17 19:26 by 李leezz
[考研] 301求调剂 +4 A_JiXing 2026-03-16 4/200 2026-03-17 17:32 by ruiyingmiao
[考研] 考研化学学硕调剂,一志愿985 +4 张vvvv 2026-03-15 6/300 2026-03-17 17:15 by ruiyingmiao
[考研] 085600材料与化工求调剂 +5 绪幸与子 2026-03-17 5/250 2026-03-17 16:40 by laoshidan
[考研] 一志愿苏州大学材料工程(085601)专硕有科研经历三项国奖两个实用型专利一项省级立项 +6 大火山小火山 2026-03-16 8/400 2026-03-17 15:05 by 无懈可击111
[考研] 材料与化工专硕调剂 +5 heming3743 2026-03-16 5/250 2026-03-17 14:03 by 勇敢太监王公公
[考研] 304求调剂 +5 素年祭语 2026-03-15 5/250 2026-03-16 17:00 by 我的船我的海
[考研] 326求调剂 +3 mlpqaz03 2026-03-15 3/150 2026-03-16 07:33 by Iveryant
[考研] 327求调剂 +6 拾光任染 2026-03-15 11/550 2026-03-15 22:47 by 拾光任染
[硕博家园] 085600 260分求调剂 +3 天空还下雨么 2026-03-13 5/250 2026-03-13 18:46 by 天空还下雨么
信息提示
请填处理意见