原题如下:用1、2、2、3、4、5这六个数字,用java写一个程序,打印出所有不同的排列,如:512234、412345等,要求:"4"不能在第三位,"3"与"5"不能相连。
解题思路:
很明显,这是一个递归算法。我们可以排列将这6个数按从小到大的顺序排一下,如果是1,2,3,4,5,6,那么会有1*2*3*4*5*6= 6!=720个递增的数。但如果是1,2,2,3,4,5,那么在这720个数中一定会有相同的数对出现(由于在这6个数中只有两个数两同,也就是说,如果有重复的数,那么一定是一对数,如122345会出现两次)。
排列的基本规则是分步进行。也就是说,要排列上面6个数,首先应该选择第一个数,这第一个数可以选择这6个数中的任意一个,如选择1.第二步是选择第二个数,这第二个数不能再选择已经选过的数,如1.因此,它只能从后面5个数中选择。如选择2。以此类推。
我们也可以在程序中模拟这一过程。源程序如下:
publicclasstest1
{
privateint[]numbers=newint[]
{1,2,3,3,4,5};
publicintn;
privateStringlastResult="";
privatebooleanvalidate(Strings)
{
if(s.compareTo(lastResult)<=0)
returnfalse;
if(s.charAt(2)=='4')
returnfalse;
if(s.indexOf("35")>=0||s.indexOf("53")>=0)
returnfalse;
returntrue;
}
publicvoidlist(Stringindex,Stringresult)
{
for(inti=0;i<numbers.length;i++)
{
if(index.indexOf(i+48)<0)
{
Strings=result+String.valueOf(numbers[i]);
if(s.length()==numbers.length)
{
if(validate(s))
{
System.out.println(s);
lastResult=s;
n++;
}
break;
}
list(index+String.valueOf(i),s);
}
}
}
publicstaticvoidmain(String[]args)
{
test1t=newtest1();
t.list("","");
System.out.println("总数:"+t.n);
}
}
public class test1
{
private int[] numbers = new int[]
{ 1, 2, 3, 3, 4, 5 };
public int n;
private String lastResult = "";
private boolean validate(String s)
{
if (s.compareTo(lastResult) <= 0)
return false;
if (s.charAt(2) == '4')
return false;
if (s.indexOf("35") >= 0 || s.indexOf("53") >= 0)
return false;
return true;
}
public void list(String index, String result)
{
for (int i = 0; i < numbers.length; i++)
{
if (index.indexOf(i + 48) < 0)
{
String s = result + String.valueOf(numbers[i]);
if (s.length() == numbers.length)
{
if (validate(s))
{
System.out.println(s);
lastResult = s;
n++;
}
break;
}
list(index + String.valueOf(i), s);
}
}
}
public static void main(String[] args)
{
test1 t = new test1();
t.list("", "");
System.out.println("总数:" + t.n);
}
}
分享到:
相关推荐
总之,这个Java算法题考察了程序员对递归算法的理解和应用,以及在解决实际问题时的逻辑思维能力和问题抽象能力。通过解题,不仅可以提升对字符串处理和递归算法的掌握,还能加深对条件判断和效率优化的认识。
在IT行业中,笔试是许多著名公司挑选优秀人才的重要环节,特别是大公司,它们通常会设置一系列严谨的测试来评估候选人的技术能力、逻辑思维和问题解决技巧。这份"著名IT公司笔试题笔试题库"正是为准备进入IT行业的...
通过对"各个著名公司的笔试题(有答案)"的深入学习,你可以对不同公司的招聘标准有更直观的理解,同时提升自己的技术实力。 首先,编程语言是IT行业的基础,包括Java、Python、C++、C#等,可能会出现在笔试题中。...
这些只是Java笔试题可能涵盖的一部分知识点,具体题目会根据招聘岗位的要求有所不同,可能还会涉及到算法、数据库操作、网络编程等内容。熟悉并熟练掌握这些知识点将有助于应对万达信息或其他公司的Java笔试。
这个压缩包可能包含了当年方正公司Java软件工程师笔试的所有题目,包括但不限于Java语言基础、JVM原理、JavaEE相关技术、数据结构与算法等内容。考生可以通过分析这些题目来了解方正对Java工程师的技能期望,并进行...
标题 "46家著名IT公司的笔试题" 涵盖了大量的技术知识点,这些知识点是IT行业,特别是互联网领域招聘过程中的常见考核内容。这包括但不限于编程语言、算法与数据结构、操作系统、网络、数据库、软件工程、计算机基础...
这个名为"46家著名IT公司的笔试题.rar"的压缩包文件显然包含了多个著名IT公司招聘过程中的笔试题目。这些题目通常涵盖了编程、算法、计算机网络、操作系统、数据结构、数据库管理、软件工程等多个IT领域的核心知识。...
阿里软件JAVA笔试题是阿里巴巴公司为招聘软件开发工程师所设计的一份笔试题目,涵盖了JAVA语言、数据结构、算法、设计模式、数据库等多方面的知识点。 本题目共有15道题目,涵盖了以下几个方面: 逻辑推理 1. 甲...
【标题】:“各公司java笔试题”所涵盖的Java编程知识点详解 【描述】:这份资源集合了2012年和2013年北京、上海等地一些知名IT公司的Java笔试题目,其中包括用友公司和亿阳信通等企业的考题。这些题目无疑是Java...
3. **数据结构与算法**:在Java笔试中,可能会遇到与数组、链表、栈、队列、树、图等数据结构相关的题目,以及排序(冒泡、快速、归并等)、查找(二分查找、哈希查找)等算法。熟练掌握这些能够提高解题效率。 4. ...
【标题】:“软件公司——华信笔试题——供大家参加笔试时参考” 这是一份与软件公司华信相关的笔试题目集锦,旨在为准备参加华信或其他类似软件公司笔试的求职者提供参考资料。这类题目通常涵盖了计算机科学和技术...
《46家著名IT公司笔试题》是一本集合了众多知名IT企业的面试笔试题目的电子书籍,对于准备进入IT行业的求职者来说,是一份极具价值的学习资料。这本书籍旨在帮助应聘者了解并熟悉IT公司的面试流程,提升自身的技术...
在准备进入世界著名公司的工作之旅时,面试和笔试环节无疑是最关键的部分。这些环节是公司评估候选人能力、技能和潜力的重要方式。为了帮助你更好地应对这些挑战,了解并熟悉各类公司的面试笔试题库是非常有益的。...
紧随其后的是《华为Java笔试题.doc》,这部分资料针对性更强,专注于华为公司对Java开发者的技术要求。在华为的笔试中,应聘者可能需要展现对JVM内存模型的理解,这是任何深入Java虚拟机工作的开发者都必须掌握的...
【标题】:“北京宏景世纪软件股份有限公司Java笔试题”涉及的Java知识点解析 【描述】:本题目来源于北京宏景世纪软件股份有限公司的Java程序员笔试环节,这通常包括了对Java基础知识、编程能力、面向对象设计以及...
"北京尔宜居科技有限公司Java笔试题" 这个标题表明这是一个与Java编程相关的考试题目集,可能是该公司在招聘Java开发人员时所使用的面试或笔试材料。这通常涵盖Java语言的基础知识、进阶特性、面向对象编程概念、多...
这份"java面试笔试试题大集合及答案(另附各大公司笔试题)"的资源正是为准备面试的Java程序员量身定制的宝典。 首先,让我们来看看编程基础部分。这部分通常包括Java语法、异常处理、面向对象设计原则等。Java语法...
【标题】:“诺明软件有限公司Java笔试题”通常是一份由诺明软件有限公司设计的用于评估应聘者Java编程技能的测试题目集。这样的试题旨在检验求职者的编程基础、面向对象设计、异常处理、集合框架、多线程、IO流、...
【标题】:“北京四维图新科技股份有限公司Java笔试题”涉及的Java知识点解析 【描述】:本题目来源于北京四维图新科技股份有限公司的Java笔试,通常这样的试题集会涵盖Java语言的基础、进阶以及实际应用等多个方面...
Java笔试题是评估应聘者技术水平和解决问题能力的重要环节,涵盖了基础语法、面向对象、数据结构、算法、JVM原理、多线程、网络协议、数据库、框架应用等多个方面。这份"java笔试题(收集了各大公司的笔试题)"资源...