主页 PC知识 网管技术 黑客帝国 安全技术 开放系统 程序设计 搜索 技术论坛

 

相关联接
 
RHU本级分类

编程语言
程序代码
WIN/*NIX编程
其他类别
JAVA专区

 
RHU阅读排行
·Java多线程程序设计详细解析
·怎样使用设计模式改善程序的结构
·设计模式学习:对于模式的“十大误解”
·用JAVA读取各种计算机文件、系统文件
·Java基础-入门知识介绍之Servlet教程
·Java基础-数据库连接池的必要性
·JAVA高级编程:EJB异常处理的最佳做法
·JAVA高级编程:Struts常见错误汇总
·J2EE:开发J2EE应用应遵循的几点原则
·Java高级编程-网络编程中的异步编程

 
 
RHU最新文章
·JAVA基础:Java 启动器如何查找类
·DOM文档操作和XML文件互相转换java实现
·在 Ajax 应用程序中实现数据交换
·JS控件autocomplete(自动完成)演示及下载
·java基础 -- JAVA字符集
·用 Spring 更好地处理 Struts 动作三种整合
·struts和hibernate谈J2EE架构数据表示
·Java 理论与实践:让 J2EE 脱离容器
·超线程多核心下Java多线程编程技术分析
·Java开发中的线程安全选择与Swing

 
 
RHU相关搜索









 
 
RHU广而告之

 
 
>您的位置:首页 -> 程序设计 -> JAVA专区
java基础:遍历m取n的所有组合

作者:RHU-TAC编辑员 来自:RHU网络采集 时间:2006-11-10 双击滚屏 收藏本页 字体:


点击 查看RHU2004全年文章


/**

  *



  * 求mn的所有组合。

  * m
个数分别为0,1,2...m-1.

  *
算法简述:

  *  
二个组合,若仅有元素顺序不同,视其为同一个组合。

  *  
左位系低位,右位系高位。

  *  
按自然的取法取第一个组合(各数位分别是:0,1,2...n-1),以后的所有组合都经上一个组合变化而来:

  *  
从右至左,找到有增量空间的位,将其加1,使高于该位的所有位,均比其左邻位大1,从而形成新的组合。

  *  
若所有位均无增量空间,说明所有组合均已被遍历。

  *  
使用该方法所生成的组合数中:对任意组合int[] c,下标小的数必定小于下标大的数.

  *


  */

 public class Combination {

  int n, m;

  int[] pre;//previous combination.
  public Combination(int n, int m) {
   this.n = n;
   this.m = m;
  }
  /**
   *
取下一个组合。可避免一次性返回所有的组合(数量巨大,浪费资源)
   * if return null,
所有组合均已取完。
   */
  public int[] next() {
   if (pre == null) {//
取第一个组合,以后的所有组合都经上一个组合变化而来。
    pre = new int[n];
    for (int i = 0; i < pre.length; i++) {
     pre[i] = i;
    }
    int[] ret = new int[n];
    System.arraycopy(pre, 0, ret, 0, n);
    return ret;
   }
   int ni = n - 1, maxNi = m - 1;
   while (pre[ni] + 1 > maxNi) {//
从右至左,找到有增量空间的位。
    ni--;
    maxNi--;
    if (ni < 0)
     return null;//
若未找到,说明了所有的组合均已取完。
   }
   pre[ni]++;
   while (++ni < n) {
    pre[ni] = pre[ni - 1] + 1;
   }
   int[] ret = new int[n];
   System.arraycopy(pre, 0, ret, 0, n);
   return ret;
  }
 }


OVER

[1] 页 RedHyphone.Union 投稿邮箱
[特别声明]:
本站文章大多搜索转载自网络中,如果侵犯了您的权利,请告之我们。本站将立即删除。
本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
查看评论】【向上滚屏】【关闭窗口】【 打印
-相关文章
  • 编程语言岁末盘点 C有望成为08年年度语言
  • MS Internet Explorer XML Parsing Buffer Overflow Exploit (vista) 0day网马生成器
  • 定时重启或关机的小工具 HTA文件
  • 快速开发一个PHP扩展
  • 如何编写PHP扩展
  • -文章评论 (关闭)
    ·还没有相关的评论!

    网上大名:
    红旋风网络技术联盟 RHUTech.Union
     
    Copyright © 2000-2007 RedHyphone.Union All Rights Reserved. 红旋风联盟版权所有.皖ICP备05011033号
    中国红旋风网络技术联盟 | www.RedHyphone.net
    Mailto:Redhyphone@gamil.com