双精度随机数数组

时间:2016-05-02 09:17:57

标签: c++ arrays random precision

做了一些功课来制作一个加载并显示数组大小为20的双精度随机数的程序。 我知道它凌乱但不擅长这个

#include <iostream> //required for cin, cout, endl
#include <cstdlib> //required for setw(), setfill()
#include <iomanip>

using namespace std;


void printArray(int arr[]); 
void fillRandArray(int arr[]);
void fillDecimalArray(double dArr[]); 
void printDecimalArray (double dArr[]);

int main()
{

    int random[21];
    double decimal[21]; 
    rand();

    fillRandArray(random); 
    fillDecimalArray(decimal);
    printArray(random); 
    printDecimalArray(decimal);


    cin.get();
    cin.get();
    return 0;
}

void fillRandArray(int arr[]) 
{
    for (int i = 1; i < 21; i++)
    {
        arr[i] = rand() % 100 + 1;
    }

}//end load of rand array

void fillDecimalArray(double dArr[ ])
{
    for (double i = 1; i <21; i++)
    {
        dArr[i] = static_cast<double>(rand()%100)/10;
    }
}

void printArray(int arr[]) 
{
    cout <<  "          5x4 Array" <<endl;
    cout <<endl;

    int cols = 5;

    for(int i = 1; i < 21; i++)
    {
        cout << setw(5) << setfill(' '); 
        cout << arr[i];
        if(i%cols == 0)
            cout << endl;
    }//end print array

}//end of printArray()

void printDecimalArray (double dArr[])
{
    int cols = 4;

    for (double i = 1; i <21; i++)
    {
        cout << setw(5) << setfill(' '); 
        int precision = 2;
        cout << dArr[i];
        cout << endl;
    }
}

需要在4x5表格中显示 错误是'无效类型'double * [double]'对于数组下标'

2 个答案:

答案 0 :(得分:4)

C ++ 11以后,您可以使用std::uniform_real_distribution

#include <random>
...
std::random_device rd;
std::mt19937 gen(rd());
const double min_v = 1.0, max_v = 100.0;
std::uniform_real_distribution<> dis(min_v, max_v);
for (int n = 0; n < 20; ++n) {
//           ^    ^ ^^
    dArr[n] = dis(gen);
}

<强> Link to example

如果您使用范围内的循环(1-20),请使用cout << arr[i-1];或使用范围(0-19)中的循环并将条件更改为if((i + 1) % cols == 0) ...

如果您必须使用rand()生成这些数字,则可以使用:

dArr[n] = 1 + (rand() % 99) + static_cast<double>(rand() % 101) / 100.0;
// Expression                         Range
// [1] rand() % 99                    0 - 98
// [2] 1 + (rand() % 99)              1 - 99
// [3] rand() % 101                   0 - 100
// [4] (rand() % 101) / 100.0         0.00 - 1.00
// [5] [2] + [4]                      1.00 - 100.0

但我们警告说:

  1. 使用任何此类表达式生成的随机数的分布不均匀。
  2. 始终将std::srand与变量(可能是std::time(0))一起使用,以便在多次执行相同二进制文件时获得不同的输出。

答案 1 :(得分:1)

for (double i = 1; i <21; i++)
{
    dArr[i] = static_cast<double>(rand()%100)/10;

您无法访问带有double的数组(即dArr[i]无效,因为我不是整数类型 - 它是双精度浮点值),必须是整数类型。只要让我成为一个整体,你就会好起来。

也就是说,你的1-20而不是0-19的循环将起作用(因为你使你的数组​​1元素太大了),但你不应该这样做。习惯写作

for (int i = 0; i < size_of_array; i++)

然后只需分配正确大小的数组(在此示例中为20,而不是21)