`
SpringArt
  • 浏览: 327176 次
社区版块
存档分类
最新评论

一著名软件公司的java笔试算法题!

阅读更多
原题如下:用1、2、2、3、4、5这六个数字,用java写一个main函数,打印出所有不同的排列,如:512234、412345等,要求:"4"不能在第三位,"3"与"5"不能相连.
我看了回贴都没有很好解决,主要是没有排除重复。
解决思路:强化题目,用1、2、2、3、4、5这六个数字排列“递增”序列。其他要求不变。
算法思路:显然是递归,初始序列122345,先从末两位(45)变化(45,54),然后末三位(345) ... 直到最后六位.怎样解决重复问题?很简单,由于是递增序列,每生成新序列可与前一生成序列比较,如<放弃当前序列。当然有更好效率,如预先预测。代码如下:
class test
{
// 当前固定部分
private String CurFixPart;
private String PreGenNum;

public static void main(String[] args)
{
test t=new test();
t.GenControll("122345");
}

// 调整字符串s位置pos字符到最前
private String shift(String s, int pos)
{
String newStr;
if (s.length()>pos+1)
newStr=s.substring(pos, pos+1)
+s.substring(0, pos)
+s.substring(pos+1);
else
newStr=s.substring(pos)
+s.substring(0, pos);
return newStr;
}

protected int Validate(String newNum)
{
String newGenNum=CurFixPart+newNum;
if (Integer.valueOf(newGenNum)<=Integer.valueOf(PreGenNum))
return 0;
if (newGenNum.substring(2,3).equals("4") ||
(newGenNum.indexOf("35")!=-1) || (newGenNum.indexOf("53")!=-1))
return 0;

PreGenNum=newGenNum;
System.out.println(newGenNum);
return 0;
}

public void GenControll(String Base)
{
PreGenNum="0";
CurFixPart="";
GenNext(Base, 0);
}

void GenNext(String varPart, int curPos)
{
if (varPart.length()==2)
{
Validate(varPart);
Validate(shift(varPart, 1));
return;
}
// Next Layer
String newGen=shift(varPart, curPos);
String SavedFixPart=CurFixPart;
CurFixPart=CurFixPart+newGen.substring(0,1);
GenNext(newGen.substring(1), 0);
CurFixPart=SavedFixPart;
// 同层递增
if (curPos==varPart.length()-1)
return;
GenNext(varPart, curPos+1);
}
}
序列122345测试通过。
有什么意见请大家多多提点。



1 把问题归结为图结构的遍历问题。实际上6个数字就是六个结点,把六个结点连接成无向连通图,对于每一个结点求这个图形的遍历路径,所有结点的遍历路径就是最后对这6个数字的排列组合结果集。
2 显然这个结果集还未达到题目的要求。从以下几个方面考虑:
1. 3,5不能相连:实际要求这个连通图的结点3,5之间不能连通, 可在构造图结构时就满足改条件,然后再遍历图。
2. 不能有重复: 考虑到有两个2,明显会存在重复结果,可以把结果集放在TreeSet中过滤重复结果
3. 4不能在第三位: 仍旧在结果集中去除满足此条件的结果。

采用二维数组定义图结构,最后的代码是:

import java.util.Iterator;
import java.util.TreeSet;

public class TestQuestion {

private String[] b = new String[]{"1", "2", "2", "3", "4", "5"};
private int n = b.length;
private boolean[] visited = new boolean[n];
private int[][] a = new int[n][n];
private String result = "";
private TreeSet set = new TreeSet();

public static void main(String[] args) {
new TestQuestion().start();
}

private void start() {

// Initial the map a[][]
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
if (i == j) {
a[i][j] = 0;
} else {
a[i][j] = 1;
}
}
}

// 3 and 5 can not be the neighbor.
a[3][5] = 0;
a[5][3] = 0;

// Begin to depth search.
for (int i = 0; i < n; i++) {
this.depthFirstSearch(i);
}

// Print result treeset.
Iterator it = set.iterator();
while (it.hasNext()) {
String string = (String) it.next();
// "4" can not be the third position.
if (string.indexOf("4") != 2) {
System.out.println(string);
}
}
}

private void depthFirstSearch(int startIndex) {
visited[startIndex] = true;
result = result + b[startIndex];
if (result.length() == n) {
// Filt the duplicate value.
set.add(result);
}
for(int j = 0; j < n; j++) {
if (a[startIndex][j] == 1 && visited[j] == false) {
depthFirstSearch(j);
} else {
continue;
}
}

// restore the result value and visited value after listing a node.
result = result.substring(0, result.length() -1);
visited[startIndex] = false;
}
}
3,5不能相连:实际要求这个连通图的结点3,5之间不能连通, 可在构造图结构时就满足改条件,然后再遍历图。
代码中请注意这几行:
// 3 and 5 can not be the neighbor.
a[3][5] = 0;
a[5][3] = 0;

只要这样定义图,根本不用在代码中写IF ELSE语句。
实际上基于图的算法好处在于,只要你能定义好满足题目要求的图结构,遍历的结果就是你要的结果,不用任何对遍历结果做任何处理。包括本题中的:4不能在第三位置,3,5不能相连,唯一
性要求,其实都可以在体现在构造的图形结构里,然后直接遍历图取得自己要的结果。而不用再次处理结果集。

只是说这里实际上对其它要求要体现在图结构里有困难(理论上是可以的),但起码3,5不能相接是很好构造的,就是上面的代码段来解释的。

关于图形数据结构建议先看看数据结构的书,主要是将如何利用二维数组描述图结构,再看看图的深度遍历实现原理。最后再应用到这个问题上来,自然就不难明白了。

转自http://www.1to2.us/java-a169514.htm
分享到:
评论
1 楼 renyangok 2007-03-05  
关于字符数组全排列的问题,这个方法非常经典,珍藏了!!!

多谢SpringArt

相关推荐

    著名IT公司笔试题笔试题库

    在IT行业中,笔试是许多著名公司挑选优秀人才的重要环节,特别是大公司,它们通常会设置一系列严谨的测试来评估候选人的技术能力、逻辑思维和问题解决技巧。这份"著名IT公司笔试题笔试题库"正是为准备进入IT行业的...

    2016年4月方正Java软件工程师笔试题

    这个压缩包可能包含了当年方正公司Java软件工程师笔试的所有题目,包括但不限于Java语言基础、JVM原理、JavaEE相关技术、数据结构与算法等内容。考生可以通过分析这些题目来了解方正对Java工程师的技能期望,并进行...

    46家著名IT公司的笔试题

    标题 "46家著名IT公司的笔试题" 涵盖了大量的技术知识点,这些知识点是IT行业,特别是互联网领域招聘过程中的常见考核内容。这包括但不限于编程语言、算法与数据结构、操作系统、网络、数据库、软件工程、计算机基础...

    46家著名IT公司的笔试题.rar

    这个名为"46家著名IT公司的笔试题.rar"的压缩包文件显然包含了多个著名IT公司招聘过程中的笔试题目。这些题目通常涵盖了编程、算法、计算机网络、操作系统、数据结构、数据库管理、软件工程等多个IT领域的核心知识。...

    阿里软件JAVA笔试题

    阿里软件JAVA笔试题是阿里巴巴公司为招聘软件开发工程师所设计的一份笔试题目,涵盖了JAVA语言、数据结构、算法、设计模式、数据库等多方面的知识点。 本题目共有15道题目,涵盖了以下几个方面: 逻辑推理 1. 甲...

    各公司java笔试题

    【标题】:“各公司java笔试题”所涵盖的Java编程知识点详解 【描述】:这份资源集合了2012年和2013年北京、上海等地一些知名IT公司的Java笔试题目,其中包括用友公司和亿阳信通等企业的考题。这些题目无疑是Java...

    软件公司——华信笔试题——供大家参加笔试时参考

    【标题】:“软件公司——华信笔试题——供大家参加笔试时参考” 这是一份与软件公司华信相关的笔试题目集锦,旨在为准备参加华信或其他类似软件公司笔试的求职者提供参考资料。这类题目通常涵盖了计算机科学和技术...

    java笔试编程题(小合集)

    紧随其后的是《华为Java笔试题.doc》,这部分资料针对性更强,专注于华为公司对Java开发者的技术要求。在华为的笔试中,应聘者可能需要展现对JVM内存模型的理解,这是任何深入Java虚拟机工作的开发者都必须掌握的...

    网龙最新秋招Java笔试题.docx

    网龙最新秋招Java笔试题 本文档是对网龙最新秋招Java笔试题的知识点总结。通过对试题的分析,我们可以总结出以下知识点: 1. 计算机网络基础知识: * PING 命令的实现机制:PING 命令发出的是 ICMP 请求报文,而...

    46家著名IT公司笔试题

    《46家著名IT公司笔试题》是一本集合了众多知名IT企业的面试笔试题目的电子书籍,对于准备进入IT行业的求职者来说,是一份极具价值的学习资料。这本书籍旨在帮助应聘者了解并熟悉IT公司的面试流程,提升自身的技术...

    世界著名公司面试笔试题

    在准备进入世界著名公司的工作之旅时,面试和笔试环节无疑是最关键的部分。这些环节是公司评估候选人能力、技能和潜力的重要方式。为了帮助你更好地应对这些挑战,了解并熟悉各类公司的面试笔试题库是非常有益的。...

    北京尔宜居科技有限公司Java笔试题

    "北京尔宜居科技有限公司Java笔试题" 这个标题表明这是一个与Java编程相关的考试题目集,可能是该公司在招聘Java开发人员时所使用的面试或笔试材料。这通常涵盖Java语言的基础知识、进阶特性、面向对象编程概念、多...

    北京宏景世纪软件股份有限公司Java笔试题

    【标题】:“北京宏景世纪软件股份有限公司Java笔试题”涉及的Java知识点解析 【描述】:本题目来源于北京宏景世纪软件股份有限公司的Java程序员笔试环节,这通常包括了对Java基础知识、编程能力、面向对象设计以及...

    java笔试题(收集了各大公司的笔试题)

    Java笔试题是评估应聘者技术水平和解决问题能力的重要环节,涵盖了基础语法、面向对象、数据结构、算法、JVM原理、多线程、网络协议、数据库、框架应用等多个方面。这份"java笔试题(收集了各大公司的笔试题)"资源...

    南瑞笔试题集合

    【南瑞笔试题集合】是针对应届毕业生设计的一系列笔试试题,旨在考察应聘者在IT领域的基础知识、专业技能和解决问题的能力。南瑞,作为中国电力行业的重要企业,其笔试环节通常涵盖计算机科学、软件工程、电力系统等...

    各个著名公司的笔试题(有答案)

    通过对"各个著名公司的笔试题(有答案)"的深入学习,你可以对不同公司的招聘标准有更直观的理解,同时提升自己的技术实力。 首先,编程语言是IT行业的基础,包括Java、Python、C++、C#等,可能会出现在笔试题中。...

    北京四维图新科技股份有限公司Java笔试题

    【标题】:“北京四维图新科技股份有限公司Java笔试题”涉及的Java知识点解析 【描述】:本题目来源于北京四维图新科技股份有限公司的Java笔试,通常这样的试题集会涵盖Java语言的基础、进阶以及实际应用等多个方面...

    2010最全的IT公司面试、笔试试题 java面试 笔试试题

    本资源集合了当年各大IT公司的面试和笔试试题,涵盖了Java语言的各种知识点,旨在帮助应聘者提升自己的技能水平,成功通过面试。 首先,Java面试通常会涉及到以下几个核心领域: 1. **Java基础知识**:包括Java...

    诺明软件有限公司Java笔试题

    【标题】:“诺明软件有限公司Java笔试题”通常是一份由诺明软件有限公司设计的用于评估应聘者Java编程技能的测试题目集。这样的试题旨在检验求职者的编程基础、面向对象设计、异常处理、集合框架、多线程、IO流、...

Global site tag (gtag.js) - Google Analytics