免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1566 | 回复: 0
打印 上一主题 下一主题

[算法] 请教算法问题,如何使N皇后算法支持多线程? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-04-12 21:46 |只看该作者 |倒序浏览
我现在用以下代码计算16皇后问题,但在多路CPU的机器上其实只使用了一个CPU,所以要使用线程来加快计算速度,我现在只知道N皇后算法其实可以看做是棋盘的第一列的每一空都先放置一个皇后,总共是N种放置位置,然后再对其它列的空逐一检测,所以理论上可以分给多个线程独立运算,但我具体不清楚怎么做。


  1. #include <stdio.h>
  2. #define N 16

  3. int a[N+1], b[2*N], c[2*N+1];

  4. int count;

  5. void queen(int i)
  6. {
  7.   int j;
  8.   
  9.   for(j=1; j<=N; j++)
  10.     {
  11.       if(a[j] + b[i+j] + c[i-j+N] == 3)
  12.         {
  13.           a[j] = 0; b[i+j] = 0; c[i-j+N] = 0;
  14.           
  15.           if(i < N)
  16.             queen(i+1);
  17.           else
  18.             count++;
  19.           
  20.           a[j] = 1; b[i+j] = 1; c[i-j+N] = 1;
  21.         }
  22.     }
  23. }

  24. int main()
  25. {  
  26.   int i;

  27.   for(i=0; i<=N; i++) a[i]=1;
  28.   for(i=0; i<=2*N; i++) b[i]=1;
  29.   for(i=0; i<=2*N-1; i++) c[i]=1;
  30.   
  31.   queen(1);

  32.   printf("%d\n", count);

  33.   return 0;
  34. }
复制代码


如果用:

  1. pthread_create (&thread, NULL, &thread_function, NULL);
复制代码


产生4个线程来计算,请问要如何修改上面的算法程序?谢谢!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP