- 论坛徽章:
- 0
|
我现在用以下代码计算16皇后问题,但在多路CPU的机器上其实只使用了一个CPU,所以要使用线程来加快计算速度,我现在只知道N皇后算法其实可以看做是棋盘的第一列的每一空都先放置一个皇后,总共是N种放置位置,然后再对其它列的空逐一检测,所以理论上可以分给多个线程独立运算,但我具体不清楚怎么做。
- #include <stdio.h>
- #define N 16
- int a[N+1], b[2*N], c[2*N+1];
- int count;
- void queen(int i)
- {
- int j;
-
- for(j=1; j<=N; j++)
- {
- if(a[j] + b[i+j] + c[i-j+N] == 3)
- {
- a[j] = 0; b[i+j] = 0; c[i-j+N] = 0;
-
- if(i < N)
- queen(i+1);
- else
- count++;
-
- a[j] = 1; b[i+j] = 1; c[i-j+N] = 1;
- }
- }
- }
- int main()
- {
- int i;
- for(i=0; i<=N; i++) a[i]=1;
- for(i=0; i<=2*N; i++) b[i]=1;
- for(i=0; i<=2*N-1; i++) c[i]=1;
-
- queen(1);
- printf("%d\n", count);
- return 0;
- }
复制代码
如果用:
- pthread_create (&thread, NULL, &thread_function, NULL);
复制代码
产生4个线程来计算,请问要如何修改上面的算法程序?谢谢! |
|