C/C++怎样生成确定范围的随机数(如[-1,1])

1、生成[-1,1]的随机数

float GetRand()
{
    return 2 .0 * rand() / RAND_MAX - 1.0;
}

    注意那个2.0不能写成2了,那样的话,你就真……

2、生成low到up(low < up)之间的随机正整数

unsigned int GetRandomInteger(int low, int up)
{
   unsigned int uiResult;

   if (low > up)
   {
      int temp = low;
      low = up;
      up = temp;
   }

   uiResult = (rand() % (up - low + 1)) + low;

   return uiResult;
}

    这里不用多说,很简单。

3、生成low到up之间的随机实数

float GetRandomReal(float low, float up)
{
   float fResult;
   
   if (low > up)
   {
      int temp = low;
      low = up;
      up = temp;
   }
   
   fResult = low + (up - low) * rand() / (RAND_MAX + 1);
   
   return fResult;
}

    这里我举个例子予以说明,假设我们欲取得[-50, 100]之间的随机数,即low=-50,up=100。语句
(up - low) * rand() / (RAND_MAX + 1)
是不是获得的正式0到150之间的随机数,再加上-50不是就获得-50到100之间的随机数了吗!其实这里取不到边界值,要取边界值很简单,RAND_MAX不加1即可。

    当然上边说的"随机数"只是在我们要求简单的情况下可取,这个你懂的!


  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
C中生成泊松分布的随机数有多种方法。一种常见的方法是使用rand()函数结合泊松分布的公式进行计算。首先,我们需要设置rand()的随机数种子,可以使用srand()函数并传入不同的种子值来获取不同的随机数序列。然后,我们可以使用rand()函数生成一个0到RAND_MAX(一般为32767)之间的随机数,并将其归一化为0到1之间的小数。接下来,我们可以使用泊松分布的公式来计算泊松分布的随机数。该公式如下: P(X=k) = (e^-λ * λ^k) / k! 其中,λ是泊松分布的参数,k是要生成随机数的值,e是自然常数。通过循环生成多个随机数,就可以得到符合泊松分布的随机数序列。 还有一种方法是使用random_device类来生成泊松分布的随机数。random_device是标准库提供的一个非确定随机数生成设备,不需要设置种子。我们可以使用random_device的operator()函数生成随机数。然后,我们可以使用泊松分布的概率质量函数来计算泊松分布的随机数。这种方法相对于使用rand()函数更加方便,不需要设置随机数种子。 下面是一个使用rand()函数生成泊松分布随机数的示例代码: ``` #include <iostream> #include <ctime> int main() { srand(time(nullptr)); int lambda = 5; // 泊松分布的参数 for (int i = 0; i < 10; ++i) { double u = static_cast<double>(rand()) / RAND_MAX; // 生成0到1之间的随机数 int k = 0; double p = exp(-lambda); while (u >= p) { u -= p; k++; p *= lambda / k; } std::cout << k << std::endl; } return 0; } ``` 注意,这个示例代码中,我们生成了10个符合参数为5的泊松分布的随机数。 另外,如果你使用的是C++11或更高版本,可以使用<random>头文件中的poisson_distribution类和random_device类来生成泊松分布的随机数。这种方法更加简洁和高效。你可以定义一个poisson_distribution对象,将泊松分布的参数传递给它,然后使用random_device类生成随机数引擎,并将其传递给poisson_distribution对象进行随机数生成。 希望以上内容对你有帮助!如果你还有其他问题,请随时提问。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [C++随机数生成](https://blog.csdn.net/CFH1021/article/details/121471117)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值