: 推 sarafciel: 平行版XD  不考虑开个特大号char array让64个一起塞吗?
: → Schottky: 咦,楼上说的很有道理
这次才是真‧平行版,分配一下使用区域还可以顺便做排版
虽说前一篇比较有 OpenMP 当 loop 用的笑点
初版有排版位置 page, row, col, 被乘数 a 和乘数 b 等等变量,比较容易写,
改成这样把变量都展开来超难读,但程式的行数就缩减很多。我故意的。
各位如果只想要整别人不想要整自己可以参考这种两阶段式作法 XDDDD
/* https://ideone.com/9Yp7YX */
#include <stdio.h>
#include <omp.h>
char mt[769];
int main(void)
{
    omp_set_num_threads(64);
#pragma omp parallel
    {
        int n, ofst;
        n = omp_get_thread_num();
        ofst = n/32*384 + n/8%4*12 + n%8*48;
        snprintf(mt+ofst, 12, "%d x %d = %2d",
            n/8+2, n%8+2, (n/8+2)*(n%8+2));
        mt[ofst+10] = n==31?'\n':' ';
        mt[ofst+11] = n/8%4==3?'\n':' ';
    }
    mt[768] = '\0';
    printf("%s\n", mt);
    return 0;
}
$ gcc -fopenmp par.c
$ ./a.out
2 x 2 =  4  3 x 2 =  6  4 x 2 =  8  5 x 2 = 10
2 x 3 =  6  3 x 3 =  9  4 x 3 = 12  5 x 3 = 15
2 x 4 =  8  3 x 4 = 12  4 x 4 = 16  5 x 4 = 20
2 x 5 = 10  3 x 5 = 15  4 x 5 = 20  5 x 5 = 25
2 x 6 = 12  3 x 6 = 18  4 x 6 = 24  5 x 6 = 30
2 x 7 = 14  3 x 7 = 21  4 x 7 = 28  5 x 7 = 35
2 x 8 = 16  3 x 8 = 24  4 x 8 = 32  5 x 8 = 40
2 x 9 = 18  3 x 9 = 27  4 x 9 = 36  5 x 9 = 45
6 x 2 = 12  7 x 2 = 14  8 x 2 = 16  9 x 2 = 18
6 x 3 = 18  7 x 3 = 21  8 x 3 = 24  9 x 3 = 27
6 x 4 = 24  7 x 4 = 28  8 x 4 = 32  9 x 4 = 36
6 x 5 = 30  7 x 5 = 35  8 x 5 = 40  9 x 5 = 45
6 x 6 = 36  7 x 6 = 42  8 x 6 = 48  9 x 6 = 54
6 x 7 = 42  7 x 7 = 49  8 x 7 = 56  9 x 7 = 63
6 x 8 = 48  7 x 8 = 56  8 x 8 = 64  9 x 8 = 72
6 x 9 = 54  7 x 9 = 63  8 x 9 = 72  9 x 9 = 81