算法实现:金币概率问题

题目: 10个房间里放着随机数量的金币。每个房间只能进入一次,并只能在一个房间中拿金币。一个人采取如下策略:前四个房间只看不拿。随后的房间只要看到比前四个房间都多的金币数,就拿。否则就拿最后一个房间的金币。 编程计算这种策略拿到最多金币的概率。


初始看本描述,感觉很晕,开始以为要用什么高深的算法来实现,想了许久没有什么头绪,后来想了想,应该是通过多次试验,看每次试验的结果,然后再统计结果,比较粗暴的行为,呵呵。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Threading;

namespace TestGailvWenti
{
    class Program
    {
        static void Main(string[] args)
        {
            int max = 1000, sure = 0;//模拟1000次
            
            for (int i = 0; i < max; i++ )
            {
                int[] arr = new int[10];
                getRandom(arr);
                printArr(arr);
                if (getTheBig(arr))
                {
                    sure++;
                    Console.WriteLine("yes");
                }
                else 
                {
                    Console.WriteLine("no");
                }
                Thread.Sleep(10);
            }
            
            Console.WriteLine((double)sure / max);
        }
        /// <summary>
        /// 计算一个随机数组利用这种方法是否能够得到最大数
        /// </summary>
        /// <param name="arr"></param>
        /// <returns></returns>
        private static bool getTheBig(int[] arr) 
        {
            int theMax = 0;
            int fourMax = 0;
            
            for(int i = 0 ; i < arr.Length ; i++)
            {
                if(i < 4 && arr[i] > fourMax)
                {
                    fourMax = arr[i];
                }

                if (arr[i] > theMax)
                {
                    theMax = arr[i];
                }
            }

            int getValue = 0;

            for (int i = 4; i < arr.Length; i++ )
            {
                if (arr[i] > fourMax)
                {
                    getValue = arr[i];
                    break;
                }

            }
            if (getValue == theMax)
                return true;
            else return false;
        }
        /// <summary>
        /// 得到一个随机数组
        /// </summary>
        /// <param name="arr"></param>
        private static void getRandom(int[] arr) 
        {
            Random r = new Random(unchecked((int)DateTime.Now.Ticks));

            for (int i = 0; i < arr.Length; i++ )
            {
                arr[i] = r.Next(100);
            }
            
        }
        /// <summary>
        /// 打印一个数组,方便查看
        /// </summary>
        /// <param name="arr"></param>
        private static void printArr(int[] arr) 
        {
            StringBuilder sb = new StringBuilder();
            foreach(var a in arr)
            {
                sb.Append(string.Format("{0:00}" , a));
                sb.Append(",");
            }
            Console.Write(sb.ToString());
        }
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值