当前位置: 首页 >> 程序设计 >> 数据结构和算法 >> 随机算法求圆周率演示程序源代码
 

随机算法求圆周率演示程序源代码

作者:lvqinhai      来源:zz     发表时间:2006-09-20     浏览次数:      字号:    

using System;
using System.Collections.Generic;
using System.Collections;
using System.Text;


namespace ConsoleApplication1
{
    class Program
    {
        static void count(Random rand)
        {
            Console.Write("请输入运算的次数:");
          
            Int32  N = 0;
            Int32 K = 0;
            try
            {
                string strinput = Console.ReadLine();
                Int32 M = Convert.ToInt32(strinput);
              
                for (Int32 i = 0; i < M; i++)
                {
                    double x = rand.NextDouble();
                    double y = rand.NextDouble();

                    if (x * x + y * y <= 1)
                    {
                        N++;
                       
                        if (x + y >= 1) K++;
                    }
                   
                }
              
                double result1 = (double)4 * N / M;
                Int32 J = M - N;
                double result2=(double)(4*K+2*J)/(K+J);
                double wucha1=result1-System.Math.PI;
                double wucha2 = result2 -System.Math.PI;
                Console.ForegroundColor = ConsoleColor.Green;
                Console.WriteLine("经过{0}次随机事件后,算法1圆周率为{1},误差为{2}.", M, result1,wucha1);
                Console.WriteLine("经过{0}次随机事件后,算法2圆周率为{1},误差为{2}.\n", M, result2,wucha2 );
                Console.ForegroundColor = ConsoleColor.White;
            }
            catch {
                Console.ForegroundColor = ConsoleColor.Gray;
                Console.Write("输入有误,");
            }
        }

    
        static void Main(string[] args)
        {
            Console.WriteLine("****************************");
            Console.WriteLine("随机算法求圆周率演示程序\n");
            Console.WriteLine("****************************\n");
            Console.ForegroundColor = ConsoleColor.White;
            Random rand = new Random();
            while (true)
            {
               
                count(rand);
           
           
            }
              
         

        }


    }
}

责任编辑 webmaster

 
 
 
 
 
评论更多>>
 
 
 
发表
 
姓名: QQ:
性别: MSN:
E-mail: 主页:
评分: 1 2 3 4 5
评论内容:
验证码:
  
  • 请遵守《互联网电子公告服务管理规定》及中华人民共和国其他各项有关法律法规。
  • 严禁发表危害国家安全、损害国家利益、破坏民族团结、破坏国家宗教政策、破坏社会稳定、侮辱、诽谤、教唆、淫秽等内容的评论 。
  • 用户需对自己在使用本站服务过程中的行为承担法律责任(直接或间接导致的)。
  • 本站管理员有权保留或删除评论内容。
  • 评论内容只代表网友个人观点,与本网站立场无关。
  •