当前位置: 首页 > 图文教程 > 认证考试 > java认证 > 用java编写1-6数字的main函数

java认证
JAVA里字符编码的探索与理解
Java基本数据类型与流的操作方法
Web应用中Java的速度真相探讨
区分JAVA引用类型和原始类型
Java程序开发过程中异常处理的特殊情况
共享内存在Java中的实现和应用
Java复杂数据类型用法
漫谈Java程序设计中的接口应用
Java数据库编程中的几个常用技巧
Java中对HashMap的深度分析与比较
JavaBean与EJB的不同
Java技术 关于EJB调用原理分析
JAVA基础:Enterprise JavaBeans 入门
JAVA:EJB 的异常处理的最佳做法
JAVA:使用Axis开发Web Service程序
Java 中对文件的读写操作之比较
深入解析Java的新特性assertion
Java基础知识:你是否了解KVM的常量池
Static和Final修饰类属性变量及初始化
什么是基于Java的责任链模式

java认证 中的 用java编写1-6数字的main函数


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-04   浏览: 263 ::
收藏到网摘: n/a

  package com.test;
  import Java.util.ArrayList;
  import java.util.List;
  /**
  * 1、2、2、3、4、5这六个数字,用java写一个main函数,打印出所有不同的排列, 如:512234、412345等.要求:"4"不能在第三位,"3"与"5"不能相连.
  *
  * @author SIMONE [email protected] 2009-6-12
  */
  public class GroupTest {
  public static List list = new ArrayList();
  /**
  * 构造字符串的所有排序组合
  *
  * @param str 将要组合成的字符
  * @param nstr 源字符串集
  */
  public static void group(String str, String nstr) {
  if (str.length() != nstr.length()) {
  String rest = getRest(str, nstr);
  for (int i = 0; i < rest.length(); i++) {
  String temp = str + rest.substring(i, i + 1);
  if (temp.indexOf("4") != 2 && temp.indexOf("35") == -1 && temp.indexOf("53") == -1) {// 过滤显示条件,如果去掉此处的判断,就是列出所有字符集的排列组合
  System.out.println(temp);
  if (!list.contains(temp)) {
  list.add(temp);
  }
  group(temp, nstr);
  }
  }
  }
  }
  /**
  * 从源字符串集中去除将要组合成的字符
  *
  * @param str 将要组合成的字符
  * @param nstr 源字符串集
  * @return 剩余字符串集
  */
  public static String getRest(String str, String nstr) {
  String rest = "";
  if (nstr.length() > str.length()) {
  rest = nstr;
  for (int i = 0; i < str.length(); i++) {
  rest = rest.replaceFirst(str.substring(i, i + 1), "");// 注意此处的replaceFirst,而不是replaceAll
  }
  }
  return rest;
  }
  public static void main(String[] args) {
  group("", "122345");
  System.out.println(list.toString());
  }
  }