mpi随机生成数组
时间: 2023-09-03 08:11:00 浏览: 96
随机数生成
5星 · 资源好评率100%
以下是使用MPI随机生成数组的示例代码:
```c
#include <stdio.h>
#include <stdlib.h>
#include <mpi.h>
#define ARRAY_SIZE 10
int main(int argc, char *argv[]) {
int rank, size;
int array[ARRAY_SIZE];
int i;
// 初始化MPI环境
MPI_Init(&argc, &argv);
// 获取进程数量和排名
MPI_Comm_size(MPI_COMM_WORLD, &size);
MPI_Comm_rank(MPI_COMM_WORLD, &rank);
// 使用进程0生成随机数组
if (rank == 0) {
srand(0);
for (i = 0; i < ARRAY_SIZE; i++) {
array[i] = rand() % 100;
}
}
// 广播随机数组到所有进程
MPI_Bcast(array, ARRAY_SIZE, MPI_INT, 0, MPI_COMM_WORLD);
// 打印数组
printf("Process %d: ", rank);
for (i = 0; i < ARRAY_SIZE; i++) {
printf("%d ", array[i]);
}
printf("\n");
// 结束MPI环境
MPI_Finalize();
return 0;
}
```
在该示例代码中,进程0生成随机数组并广播到所有进程。每个进程打印接收到的数组。注意,使用不同的随机种子可能会得到不同的数组。
阅读全文