免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: rdcwayx
打印 上一主题 下一主题

排列组合问题 [复制链接]

论坛徽章:
0
1 [报告]
发表于 2007-04-02 16:33 |显示全部楼层

标准的next_permutation实现方式

  1. public boolean nextPermutation(int[] a) {
  2.                 int i, j;
  3.                 for (i = a.length - 1; i > 0; i--) {
  4.                         if (a[i] > a[i - 1]) {
  5.                                 break;
  6.                         }
  7.                 }
  8.                 i--;
  9.                 if (i == -1)
  10.                         return false;
  11.                 for (j = a.length - 1; j >= 0; j--) {
  12.                         if (a[j] > a[i])
  13.                                 break;
  14.                 }
  15.                 int t = a[j];
  16.                 a[j] = a[i];
  17.                 a[i] = t;
  18.                 for (i = i + 1, j = a.length - 1; i < j; i++, j--) {
  19.                         t = a[i];
  20.                         a[i] = a[j];
  21.                         a[j] = t;
  22.                 }
  23.                 return true;
  24.         }
复制代码

论坛徽章:
0
2 [报告]
发表于 2007-04-04 13:46 |显示全部楼层
不懂为什么所谓模版的效率要高
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP