分享

某高人整理的Java就业面试题大全【2】

 londonKu 2012-05-06
4. 算法与编程

1.判断身份证:要么是15位,要么是18位,最后一位可以为字母,并写程序提出其中的年月日。


答:我们可以用正则表达式来定义复杂的字符串格式,(\d{17}[0-9a-zA-Z]|\d{14}[0-9a-zA-Z])可以用来判断是否为合法的15位或18位身份证号码。
因为15位和18位的身份证号码都是从7位到第12位为身份证为日期类型。这样我们可以设计出更精确的正则模式,使身份证号的日期合法,这样我们的正则模 式可以进一步将日期部分的正则修改为[12][0-9]{3}[01][0-9][123][0-9],当然可以更精确的设置日期。

在jdk的java.util.Regex包中有实现正则的类,Pattern和Matcher。以下是实现代码:

  1. import java.util.regex.Matcher;  
  2. import java.util.regex.Pattern;  
  3.   
  4. public class RegexTest {  
  5.   
  6. /** 
  7. * @param args 
  8. */  
  9. public static void main(String[] args) {  
  10.   
  11. // 测试是否为合法的身份证号码  
  12. String[] strs = { "130681198712092019""13068119871209201x",  
  13. "13068119871209201""123456789012345""12345678901234x",  
  14. "1234567890123" };  
  15. Pattern p1 = Pattern.compile("(\\d{17}[0-9a-zA-Z]|\\d{14}[0-9a-zA-Z])");  
  16. for (int i = 0; i < strs.length; i++) {  
  17. Matcher matcher = p1.matcher(strs[i]);  
  18. System.out.println(strs[i] + ":" + matcher.matches());  
  19. }  
  20.   
  21. Pattern p2 = Pattern.compile("\\d{6}(\\d{8}).*"); // 用于提取出生日字符串  
  22. Pattern p3 = Pattern.compile("(\\d{4})(\\d{2})(\\d{2})");// 用于将生日字符串进行分解为年月日  
  23. for (int i = 0; i < strs.length; i++) {  
  24. Matcher matcher = p2.matcher(strs[i]);  
  25. boolean b = matcher.find();  
  26. if (b) {  
  27. String s = matcher.group(1);  
  28. Matcher matcher2 = p3.matcher(s);  
  29. if (matcher2.find()) {  
  30. System.out  
  31. .println("生日为" + matcher2.group(1) + "年"  
  32. + matcher2.group(2) + "月"  
  33. + matcher2.group(3) + "日");  
  34. }  
  35. }  
  36.   
  37. }  
  38.   
  39. }  
  40.   
  41. }  

1、编写一个程序,将a.txt文件中的单词与b.txt文件中的单词交替合并到c.txt文件中,a.txt文件中的单词用回车符分隔,b.txt文件中用回车或空格进行分隔。
答:

  1. package cn.itcast;  
  2.   
  3. import java.io.File;  
  4. import java.io.FileReader;  
  5. import java.io.FileWriter;  
  6.   
  7. public class MainClass{  
  8. public static void main(String[] args) throws Exception{  
  9. FileManager a = new FileManager("a.txt",new char[]{'\n'});  
  10. FileManager b = new FileManager("b.txt",new char[]{'\n',' '});    
  11. FileWriter c = new FileWriter("c.txt");  
  12. String aWord = null;  
  13. String bWord = null;  
  14. while((aWord = a.nextWord()) !=null ){  
  15. c.write(aWord + "\n");  
  16. bWord = b.nextWord();  
  17. if(bWord != null)  
  18. c.write(bWord + "\n");  
  19. }  
  20.   
  21. while((bWord = b.nextWord()) != null){  
  22. c.write(bWord + "\n");  
  23. }     
  24. c.close();  
  25. }  
  26.   
  27. }  
  28.   
  29.   
  30. class FileManager{  
  31.   
  32. String[] words = null;  
  33. int pos = 0;  
  34. public FileManager(String filename,char[] seperators) throws Exception{  
  35. File f = new File(filename);  
  36. FileReader reader = new FileReader(f);  
  37. char[] buf = new char[(int)f.length()];  
  38. int len = reader.read(buf);  
  39. String results = new String(buf,0,len);  
  40. String regex = null;  
  41. if(seperators.length >1 ){  
  42. regex = "" + seperators[0] + "|" + seperators[1];  
  43. }else{  
  44. regex = "" + seperators[0];  
  45. }  
  46. words = results.split(regex);  
  47. }  
  48.   
  49. public String nextWord(){  
  50. if(pos == words.length)  
  51. return null;  
  52. return words[pos++];  
  53. }  
  54.   
  55. }  

1、编写一个程序,将d:\java目录下的所有.java文件复制到d:\jad目录下,并将原来文件的扩展名从.java改为.jad。
(大家正在做上面这道题,网上迟到的朋友也请做做这道题,找工作必须能编写这些简单问题的代码!)
答:listFiles方法接受一个FileFilter对象,这个FileFilter对象就是过虑的策略对象,不同的人提供不同的FileFilter实现,即提供了不同的过滤策略。

  1. import java.io.File;  
  2. import java.io.FileInputStream;  
  3. import java.io.FileOutputStream;  
  4. import java.io.FilenameFilter;  
  5. import java.io.IOException;  
  6. import java.io.InputStream;  
  7. import java.io.OutputStream;  
  8.   
  9. public class Jad2Java {  
  10.   
  11. public static void main(String[] args) throws Exception {  
  12. File srcDir = new File("java");  
  13. if(!(srcDir.exists() && srcDir.isDirectory()))  
  14. throw new Exception("目录不存在");  
  15. File[] files = srcDir.listFiles(  
  16. new FilenameFilter(){  
  17.   
  18. public boolean accept(File dir, String name) {  
  19. return name.endsWith(".java");  
  20. }  
  21.   
  22. }  
  23. );  
  24.   
  25. System.out.println(files.length);  
  26. File destDir = new File("jad");  
  27. if(!destDir.exists()) destDir.mkdir();  
  28. for(File f :files){  
  29. FileInputStream fis = new FileInputStream(f);  
  30. String destFileName = f.getName().replaceAll("\\.javatiny_mce_markerquot;, ".jad");  
  31. FileOutputStream fos = new FileOutputStream(new File(destDir,destFileName));  
  32. copy(fis,fos);  
  33. fis.close();  
  34. fos.close();  
  35. }  
  36. }  
  37.   
  38. private static void copy(InputStream ips,OutputStream ops) throws Exception{  
  39. int len = 0;  
  40. byte[] buf = new byte[1024];  
  41. while((len = ips.read(buf)) != -1){  
  42. ops.write(buf,0,len);  
  43. }  
  44.   
  45. }  
  46. }  

由本题总结的思想及策略模式的解析:
1.
class jad2java{
1. 得到某个目录下的所有的java文件集合
1.1 得到目录 File srcDir = new File("d:\\java");
1.2 得到目录下的所有java文件:File[] files = srcDir.listFiles(new MyFileFilter());
1.3 只想得到.java的文件
: class MyFileFilter implememyts FileFilter{
public boolean accept(File pathname){
return pathname.getName().endsWith(".java")
}
}


2.将每个文件复制到另外一个目录,并改扩展名
2.1 得到目标目录,如果目标目录不存在,则创建之
2.2 根据源文件名得到目标文件名,注意要用正则表达式,注意.的转义。
2.3 根据表示目录的File和目标文件名的字符串,得到表示目标文件的File。
//要在硬盘中准确地创建出一个文件,需要知道文件名和文件的目录。 
2.4 将源文件的流拷贝成目标文件流,拷贝方法独立成为一个方法,方法的参数采用抽象流的形式。
//方法接受的参数类型尽量面向父类,越抽象越好,这样适应面更宽广。

}


分析listFiles方法内部的策略模式实现原理
File[] listFiles(FileFilter filter){
File[] files = listFiles();
//Arraylist acceptedFilesList = new ArrayList();
File[] acceptedFiles = new File[files.length];
int pos = 0;
for(File file: files){
boolean accepted = filter.accept(file);
if(accepted){
//acceptedFilesList.add(file);
acceptedFiles[pos++] = file;
}
}


Arrays.copyOf(acceptedFiles,pos);
//return (File[])accpetedFilesList.toArray();


}


1、编写一个截取字符串的函数,输入为一个字符串和字节数,输出为按字节截取的字符串,但要保证汉字不被截取半个,如"我ABC",4,应该截取"我AB",输入"我ABC汉DEF",6,应该输出"我ABC",而不是"我ABC+汉的半个"。
答:
首先要了解中文字符有多种编码及各种编码的特征。
假设n为要截取的字节数。

  1. public static void main(String[] args) throws Exception{  
  2. String str = "我a爱中华abc我爱传智def';  
  3. String str = "我ABC汉";  
  4. int num = trimGBK(str.getBytes("GBK"),5);  
  5. System.out.println(str.substring(0,num) );  
  6. }  
  7.   
  8. public static int trimGBK(byte[] buf,int n){  
  9. int num = 0;  
  10. boolean bChineseFirstHalf = false;  
  11. for(int i=0;i<n;i++)  
  12. {  
  13. if(buf[i]<0 && !bChineseFirstHalf){  
  14. bChineseFirstHalf = true;  
  15. }else{  
  16. num++;  
  17. bChineseFirstHalf = false;    
  18. }  
  19. }  
  20. return num;  
  21. }  

1、有一个字符串,其中包含中文字符、英文字符和数字字符,请统计和打印出各个字符的个数。
答:哈哈,其实包含中文字符、英文字符、数字字符原来是出题者放的烟雾弹。

  1. String content = "中国aadf的111萨bbb菲的zz萨菲";  
  2. HashMap map = new HashMap();  
  3. for(int i=0;i<content.length;i++)  
  4. {  
  5. char c = content.charAt(i);  
  6. Integer num = map.get(c);  
  7. if(num == null)  
  8. num = 1;  
  9. else  
  10. num = num + 1;  
  11. map.put(c,num);  
  12. }   
  13. for(Map.EntrySet entry : map)  
  14. {  
  15. system.out.println(entry.getkey() + ":" + entry.getValue());  
  16. }  

估计是当初面试的那个学员表述不清楚,问题很可能是:
如果一串字符如"aaaabbc中国1512"要分别统计英文字符的数量,中文字符的数量,和数字字符的数量,假设字符中没有中文字符、英文字符、数字字符之外的其他特殊字符。

  1. int engishCount;  
  2. int chineseCount;  
  3. int digitCount;  
  4. for(int i=0;i<str.length;i++)  
  5. {  
  6. char ch = str.charAt(i);  
  7. if(ch>='0' && ch<='9')  
  8. {  
  9. digitCount++  
  10. }  
  11. else if((ch>='a' && ch<='z') || (ch>='A' && ch<='Z'))  
  12. {  
  13. engishCount++;  
  14. }  
  15. else  
  16. {  
  17. chineseCount++;  
  18. }  
  19. }  
  20. System.out.println(...............);  



1、说明生活中遇到的二叉树,用java实现二叉树
这是组合设计模式。

我有很多个(假设10万个)数据要保存起来,以后还需要从保存的这些数据中检索是否存在某个数据,(我想说出二叉树的好处,该怎么说呢?那就是说别人的缺 点),假如存在数组中,那么,碰巧要找的数字位于99999那个地方,那查找的速度将很慢,因为要从第1个依次往后取,取出来后进行比较。平衡二叉树(构 建平衡二叉树需要先排序,我们这里就不作考虑了)可以很好地解决这个问题,但二叉树的遍历(前序,中序,后序)效率要比数组低很多,原理如下图:



代码如下:

  1. package com.huawei.interview;  
  2.   
  3. public class Node {  
  4. public int value;  
  5. public Node left;  
  6. public Node right;  
  7.   
  8. public void store(int value)  
  9. {  
  10. if(value<this.value)  
  11. {  
  12. if(left == null)  
  13. {  
  14. left = new Node();  
  15. left.value=value;  
  16. }  
  17. else  
  18. {  
  19. left.store(value);  
  20. }  
  21. }  
  22. else if(value>this.value)  
  23. {  
  24. if(right == null)  
  25. {  
  26. right = new Node();  
  27. right.value=value;  
  28. }  
  29. else  
  30. {  
  31. right.store(value);  
  32. }     
  33. }  
  34. }  
  35.   
  36. public boolean find(int value)  
  37. {     
  38. System.out.println("happen " + this.value);  
  39. if(value == this.value)  
  40. {  
  41. return true;  
  42. }  
  43. else if(value>this.value)  
  44. {  
  45. if(right == nullreturn false;  
  46. return right.find(value);  
  47. }else  
  48. {  
  49. if(left == nullreturn false;  
  50. return left.find(value);  
  51. }  
  52.   
  53. }  
  54.   
  55. public void preList()  
  56. {  
  57. System.out.print(this.value + ",");  
  58. if(left!=null) left.preList();  
  59. if(right!=null) right.preList();  
  60. }  
  61.   
  62. public void middleList()  
  63. {  
  64. if(left!=null) left.preList();  
  65. System.out.print(this.value + ",");  
  66. if(right!=null) right.preList();      
  67. }  
  68. public void afterList()  
  69. {  
  70. if(left!=null) left.preList();  
  71. if(right!=null) right.preList();  
  72. System.out.print(this.value + ",");   
  73. }     
  74. public static void main(String [] args)  
  75. {  
  76. int [] data = new int[20];  
  77. for(int i=0;i<data.length;i++)  
  78. {  
  79. data[i] = (int)(Math.random()*100) + 1;  
  80. System.out.print(data[i] + ",");  
  81. }  
  82. System.out.println();  
  83.   
  84. Node root = new Node();  
  85. root.value = data[0];  
  86. for(int i=1;i<data.length;i++)  
  87. {  
  88. root.store(data[i]);  
  89. }  
  90.   
  91. root.find(data[19]);  
  92.   
  93. root.preList();  
  94. System.out.println();  
  95. root.middleList();  
  96. System.out.println();     
  97. root.afterList();  
  98. }  
  99. }  

-----------------又一次临场写的代码---------------------------

  1. import java.util.Arrays;  
  2. import java.util.Iterator;  
  3.   
  4. public class Node {  
  5. private Node left;  
  6. private Node right;  
  7. private int value;  
  8. //private int num;  
  9.   
  10. public Node(int value){  
  11. this.value = value;  
  12. }  
  13. public void add(int value){  
  14.   
  15. if(value > this.value)  
  16. {  
  17. if(right != null)  
  18. right.add(value);  
  19. else  
  20. {  
  21. Node node = new Node(value);      
  22. right = node;  
  23. }  
  24. }  
  25. else{  
  26. if(left != null)  
  27. left.add(value);  
  28. else  
  29. {  
  30. Node node = new Node(value);      
  31. left = node;  
  32. }     
  33. }  
  34. }  
  35.   
  36. public boolean find(int value){  
  37. if(value == this.value) return true;  
  38. else if(value > this.value){  
  39. if(right == nullreturn false;  
  40. else return right.find(value);  
  41. }else{  
  42. if(left == nullreturn false;  
  43. else return left.find(value);     
  44. }  
  45.   
  46. }  
  47.   
  48. public void display(){  
  49. System.out.println(value);  
  50. if(left != null) left.display();  
  51. if(right != null) right.display();  
  52.   
  53. }  
  54.   
  55. /*public Iterator iterator(){ 
  56.  
  57. }*/  
  58.   
  59. public static void main(String[] args){  
  60. int[] values = new int[8];  
  61. for(int i=0;i<8;i++){  
  62. int num = (int)(Math.random() * 15);  
  63. //System.out.println(num);  
  64. //if(Arrays.binarySearch(values, num)<0)  
  65. if(!contains(values,num))  
  66. values[i] = num;  
  67. else  
  68. i--;  
  69. }  
  70.   
  71. System.out.println(Arrays.toString(values));  
  72.   
  73. Node root = new Node(values[0]);  
  74. for(int i=1;i<values.length;i++){  
  75. root.add(values[i]);  
  76. }  
  77.   
  78. System.out.println(root.find(13));  
  79.   
  80. root.display();  
  81.   
  82. }  
  83.   
  84. public static boolean contains(int [] arr, int value){  
  85. int i = 0;  
  86. for(;i<arr.length;i++){  
  87. if(arr[i] == value) return true;  
  88.   
  89. }  
  90. return false;  
  91. }  
  92.   
  93. }  

1、从类似如下的文本文件中读取出所有的姓名,并打印出重复的姓名和重复的次数,并按重复次数排序:
1,张三,28
2,李四,35
3,张三,28
4,王五,35
5,张三,28
6,李四,35
7,赵六,28
8,田七,35


程序代码如下(答题要博得用人单位的喜欢,包名用该公司,面试前就提前查好该公司的网址,如果查不到,现场问也是可以的。还要加上实现思路的注释):

  1. package com.huawei.interview;  
  2.   
  3. import java.io.BufferedReader;  
  4. import java.io.IOException;  
  5. import java.io.InputStream;  
  6. import java.io.InputStreamReader;  
  7. import java.util.Comparator;  
  8. import java.util.HashMap;  
  9. import java.util.Iterator;  
  10. import java.util.Map;  
  11. import java.util.TreeSet;  
  12.   
  13.   
  14. public class GetNameTest {  
  15.   
  16. /** 
  17. * @param args 
  18. */  
  19. public static void main(String[] args) {  
  20. // TODO Auto-generated method stub  
  21. //InputStream ips = GetNameTest.class.getResourceAsStream("/com/huawei/interview/info.txt");  
  22. //用上一行注释的代码和下一行的代码都可以,因为info.txt与GetNameTest类在同一包下面,所以,可以用下面的相对路径形式  
  23.   
  24. Map results = new HashMap();  
  25. InputStream ips = GetNameTest.class.getResourceAsStream("info.txt");  
  26. BufferedReader in = new BufferedReader(new InputStreamReader(ips));  
  27. String line = null;  
  28. try {  
  29. while((line=in.readLine())!=null)  
  30. {  
  31. dealLine(line,results);  
  32. }  
  33. sortResults(results);  
  34. catch (IOException e) {  
  35. // TODO Auto-generated catch block  
  36. e.printStackTrace();  
  37. }  
  38. }  
  39.   
  40. static class User  
  41. {  
  42. public String name;  
  43. public Integer value;  
  44. public User(String name,Integer value)  
  45. {  
  46. this.name = name;  
  47. this.value = value;  
  48. }  
  49.   
  50. @Override  
  51. public boolean equals(Object obj) {  
  52. // TODO Auto-generated method stub  
  53.   
  54. //下面的代码没有执行,说明往treeset中增加数据时,不会使用到equals方法。  
  55. boolean result = super.equals(obj);  
  56. System.out.println(result);  
  57. return result;  
  58. }  
  59. }  
  60.   
  61. private static void sortResults(Map results) {  
  62. // TODO Auto-generated method stub  
  63. TreeSet sortedResults = new TreeSet(  
  64. new Comparator(){  
  65. public int compare(Object o1, Object o2) {  
  66. // TODO Auto-generated method stub  
  67. User user1 = (User)o1;  
  68. User user2 = (User)o2;  
  69. /*如果compareTo返回结果0,则认为两个对象相等,新的对象不会增加到集合中去 
  70. * 所以,不能直接用下面的代码,否则,那些个数相同的其他姓名就打印不出来。 
  71. * */  
  72.   
  73. //return user1.value-user2.value;  
  74. //return user1.value<user2.value?-1:user1.value==user2.value?0:1;  
  75. if(user1.value<user2.value)  
  76. {  
  77. return -1;  
  78. }else if(user1.value>user2.value)  
  79. {  
  80. return 1;  
  81. }else  
  82. {  
  83. return user1.name.compareTo(user2.name);  
  84. }  
  85. }  
  86.   
  87. }  
  88. );  
  89. Iterator iterator = results.keySet().iterator();  
  90. while(iterator.hasNext())  
  91. {  
  92. String name = (String)iterator.next();  
  93. Integer value = (Integer)results.get(name);  
  94. if(value > 1)  
  95. {     
  96. sortedResults.add(new User(name,value));      
  97. }  
  98. }  
  99.   
  100. printResults(sortedResults);  
  101. }  
  102. private static void printResults(TreeSet sortedResults)   
  103. {  
  104. Iterator iterator = sortedResults.iterator();  
  105. while(iterator.hasNext())  
  106. {  
  107. User user = (User)iterator.next();  
  108. System.out.println(user.name + ":" + user.value);  
  109. }     
  110. }  
  111. public static void dealLine(String line,Map map)  
  112. {  
  113. if(!"".equals(line.trim()))  
  114. {  
  115. String [] results = line.split(",");  
  116. if(results.length == 3)  
  117. {  
  118. String name = results[1];  
  119. Integer value = (Integer)map.get(name);  
  120. if(value == null) value = 0;  
  121. map.put(name,value + 1);  
  122. }  
  123. }  
  124. }  
  125.   
  126. }  

48、写一个Singleton出来。
第一种:饱汉模式
public class SingleTon {
private SingleTon(){
}


//实例化放在静态代码块里可提高程序的执行效率,但也可能更占用空间
private final static SingleTon instance = new SingleTon();
public static SingleTon getInstance(){
return instance;
}
}


第二种:饥汉模式
public class SingleTon {
private SingleTon(){}


private static instance = null;//new SingleTon();


public static synchronized SingleTon getInstance(){
if(instance == null)
instance = new SingleTon();
return instance;
}
}


第三种:用枚举
public enum SingleTon{
ONE;


}


第三:更实际的应用(在什么情况用单例)
public class SequenceGenerator{
//下面是该类自身的业务功能代码
private int count = 0;


public synchronized int getSequence(){
++count;
}


//下面是把该类变成单例的代码
private SequenceGenerator(){}
private final static instance = new SequenceGenerator();
public static SingleTon getInstance(){
return instance;
}


}


第四:
public class MemoryDao
{
private HashMap map = new HashMap();


public void add(Student stu1){ 
map.put(SequenceGenerator.getInstance().getSequence(),stu1);
}


//把MemoryDao变成单例 
}




Singleton模式主要作用是保证在Java应用程序中,一个类Class只有一个实例存在。 
一般Singleton模式通常有几种种形式: 
第一种形式: 定义一个类,它的构造函数为private的,它有一个static的private的该类变量,在类初始化时实例话,通过一个public的getInstance方法获取对它的引用,继而调用其中的方法。 
public class Singleton { 
private Singleton(){} 
//在自己内部定义自己一个实例,是不是很奇怪? 
//注意这是private 只供内部调用 
private static Singleton instance = new Singleton(); 
//这里提供了一个供外部访问本class的静态方法,可以直接访问   
public static Singleton getInstance() { 
return instance;    


第二种形式: 
public class Singleton { 
private static Singleton instance = null; 
public static synchronized Singleton getInstance() { 
//这个方法比上面有所改进,不用每次都进行生成对象,只是第一次      
//使用时生成实例,提高了效率! 
if (instance==null) 
instance=new Singleton(); 
return instance;   


其他形式: 
定义一个类,它的构造函数为private的,所有方法为static的。 
一般认为第一种形式要更加安全些 


7、递归算法题1
一个整数,大于0,不用循环和本地变量,按照n,2n,4n,8n的顺序递增,当值大于5000时,把值按照指定顺序输出来。
例:n=1237
则输出为:
1237,
2474,
4948,
9896,
9896,
4948,
2474,
1237,
提示:写程序时,先致谢按递增方式的代码,写好递增的以后,再增加考虑递减部分。
public static void doubleNum(int n)
{
System.out.println(n);
if(n<=5000)
doubleNum(n*2);
System.out.println(n);
}




7、递归算法题2
第1个人10,第2个比第1个人大2岁,依次递推,请用递归方式计算出第8个人多大?

  1. package cn.itcast;  
  2.   
  3. import java.util.Date;  
  4.   
  5. public class A1 {  
  6.   
  7. public static void main(String [] args)  
  8. {  
  9. System.out.println(computeAge(8));  
  10. }  
  11.   
  12. public static int computeAge(int n)  
  13. {  
  14. if(n==1return 10;  
  15. return computeAge(n-1) + 2;  
  16. }  
  17. }  
  18.   
  19. public static void toBinary(int n,StringBuffer result)  
  20. {  
  21.   
  22. if(n/2 != 0)  
  23. toBinary(n/2,result);  
  24. result.append(n%2);   
  25. }  

94、排序都有哪几种方法?请列举。用JAVA实现一个快速排序。 
本人只研究过冒泡排序、选择排序和快速排序,下面是快速排序的代码:

  1. public class QuickSort {  
  2. /** 
  3. * 快速排序 
  4. * @param strDate 
  5. * @param left 
  6. * @param right 
  7. */  
  8. public void quickSort(String[] strDate,int left,int right){  
  9. String middle,tempDate;  
  10. int i,j;  
  11. i=left;  
  12. j=right;  
  13. middle=strDate[(i+j)/2];  
  14. do{  
  15. while(strDate[i].compareTo(middle)<0&& i<right)  
  16. i++; //找出左边比中间值大的数  
  17. while(strDate[j].compareTo(middle)>0&& j>left)  
  18. j--; //找出右边比中间值小的数  
  19. if(i<=j){ //将左边大的数和右边小的数进行替换   
  20. tempDate=strDate[i];  
  21. strDate[i]=strDate[j];  
  22. strDate[j]=tempDate;  
  23. i++;  
  24. j--;  
  25. }  
  26. }while(i<=j); //当两者交错时停止  
  27.   
  28. if(i<right){  
  29. quickSort(strDate,i,right);//从  
  30. }  
  31. if(j>left){  
  32. quickSort(strDate,left,j);  
  33. }  
  34. }  
  35. /** 
  36. * @param args 
  37. */  
  38. public static void main(String[] args){  
  39. String[] strVoid=new String[]{"11","66","22","0","55","22","0","32"};  
  40. QuickSort sort=new QuickSort();  
  41. sort.quickSort(strVoid,0,strVoid.length-1);  
  42. for(int i=0;i<strVoid.length;i++){  
  43. System.out.println(strVoid[i]+" ");  
  44. }  
  45. }  
  46.   
  47.   
  48. }  

7、有数组a[n],用java代码将数组元素顺序颠倒
//用下面的也可以
//for(int i=0,int j=a.length-1;i<j;i++,j--) 是否等效于 for(int i=0;i<a.length/2;i++)呢?

  1. import java.util.Arrays;  
  2.   
  3. public class SwapDemo{  
  4.   
  5. public static void main(String[] args){  
  6. int [] a = new int[]{  
  7. (int)(Math.random() * 1000),  
  8. (int)(Math.random() * 1000),  
  9. (int)(Math.random() * 1000),  
  10. (int)(Math.random() * 1000),      
  11. (int)(Math.random() * 1000)   
  12. };    
  13.   
  14. System.out.println(a);  
  15. System.out.println(Arrays.toString(a));  
  16. swap(a);  
  17. System.out.println(Arrays.toString(a));   
  18. }  
  19.   
  20. public static void swap(int a[]){  
  21. int len = a.length;  
  22. for(int i=0;i<len/2;i++){  
  23. int tmp = a[i];  
  24. a[i] = a[len-1-i];  
  25. a[len-1-i] = tmp;  
  26. }  
  27. }  
  28. }  

2.金额转换,阿拉伯数字的金额转换成中国传统的形式如:(¥1011)->(一千零一拾一元整)输出。
去零的代码:

return sb.reverse().toString().replaceAll("零[拾佰仟]","零").replaceAll("零+万","万").replaceAll("零+元","元").replaceAll("零+","零");

  1. public class RenMingBi {  
  2.   
  3. /** 
  4. * @param args add by zxx ,Nov 29, 2008 
  5. */  
  6. private static final char[] data = new char[]{  
  7. '零','壹','贰','叁','肆','伍','陆','柒','捌','玖'  
  8. };   
  9. private static final char[] units = new char[]{  
  10. '元','拾','佰','仟','万','拾','佰','仟','亿'  
  11. };  
  12. public static void main(String[] args) {  
  13. // TODO Auto-generated method stub  
  14. System.out.println(  
  15. convert(135689123));  
  16. }  
  17.   
  18. public static String convert(int money)  
  19. {  
  20. StringBuffer sbf = new StringBuffer();  
  21. int unit = 0;  
  22. while(money!=0)  
  23. {  
  24. sbf.insert(0,units[unit++]);  
  25. int number = money%10;  
  26. sbf.insert(0, data[number]);  
  27. money /= 10;  
  28. }  
  29.   
  30. return sbf.toString();  
  31. }  
  32. }  

5. html&JavaScript&ajax部分


1. 判断第二个日期比第一个日期大
如何用脚本判断用户输入的的字符串是下面的时间格式2004-11-21 必须要保证用户的输入是此格式,并且是时间,比如说月份不大于12等等,另外我需要用户输入两个,并且后一个要比前一个晚,只允许用JAVASCRIPT,请详细帮助作答,, 
//这里可用正则表达式判断提前判断一下格式,然后按下提取各时间字段内容
<script type="text/javascript">
window.onload = function()
{
//这么写是为了实现js代码与html代码的分离,当我修改js时,不能影响html代码。
document.getElementById("frm1").onsubmit = 
function(){
var d1 = this.d1.value;
var d2 = this.d2.value;
if(!verifyDate (d1)) {alert("第一个日期格式不对");return false;}
if(!verifyDate (d2)) {alert("第二个日期格式不对");return false;}
if(!compareDate(d1,d2)) {alert("第二个日期比第一日期小");return false;}
};
}


function compareDate(d1,d2)
{
var arrayD1 = d1.split("-");
var date1 = new Date(arrayD1[0],arrayD1[1],arrayD1[2]);
var arrayD2 = d2.split("-");
var date2 = new Date(arrayD2[0],arrayD2[1],arrayD2[2]);
if(date1 > date2) return false;
return true;



function verifyDate(d)
{
var datePattern = /^\d{4}-(0?[1-9]|1[0-2])-(0?[1-9]|[1-2]\d|3[0-1])$/;
return datePattern.test(d);
}
</script>


<form id="frm1" action="xxx.html">
<input type="text" name="d1" />
<input type="text" name="d2" />
<input type="submit"/>
</form>
1. 用table显示n条记录,每3行换一次颜色,即1,2,3用红色字体,4,5,6用绿色字体,7,8,9用红颜色字体。
<body>
<table id="tbl">
<tr><td>1</td></tr>
<tr><td>2</td></tr>
<tr><td>3</td></tr>
<tr><td>4</td></tr>
<tr><td>5</td></tr>
<tr><td>6</td></tr>
<tr><td>7</td></tr>
<tr><td>8</td></tr>
<tr><td>9</td></tr>
<tr><td>10</td></tr>
</table>
</body>
<script type="text/javascript">
window.onload=function()
{
var tbl = document.getElementById("tbl");
rows = tbl.getElementsByTagName("tr");
for(i=0;i<rows.length;i++)
{
var j = parseInt(i/3);
if(j%2==0) rows[i].style.backgroundColor="#f00";
else rows[i].style.backgroundColor="#0f0";
}
}
</script>
1、HTML 的 form 提交之前如何验证数值文本框的内容全部为数字? 否则的话提示用户并终止提交?
<form onsubmit='return chkForm(this)'>
<input type="text" name="d1"/>
<input type="submit"/>
</form>
<script type="text/javascript" />
function chkForm(this)

var value = thist.d1.value;
var len = value.length;
for(var i=0;i<len;i++)
{
if(value.charAt(i)>"9" || value.charAt(i)<"0")
{
alert("含有非数字字符"); return false;
}
}
return true;
}
</script>


2、请写出用于校验HTML文本框中输入的内容全部为数字的javascript代码
<input type="text" id="d1" onblur=" chkNumber (this)"/>
<script type="text/javascript" />
function chkNumber(eleText) 

var value = eleText.value;
var len = value.length;
for(var i=0;i<len;i++)
{
if(value.charAt(i)>"9" || value.charAt(i)<"0")
{
alert("含有非数字字符"); 
eleText.focus();
break; 
}
}
}
</script>
除了写完代码,还应该在网页上写出实验步骤和在代码中加入实现思路,让面试官一看就明白你的意图和检查你的结果。


1、说说你用过那些ajax技术和框架,说说它们的区别
答:去掉对web.xml的监视,把jsp提前编辑成Servlet。
有富余物理内存的情况,加大tomcat使用的jvm的内存



6. Java web部分


ww

1、Tomcat的优化经验
答:去掉对web.xml的监视,把jsp提前编辑成Servlet。
有富余物理内存的情况,加大tomcat使用的jvm的内存




1、HTTP请求的GET与POST方式的区别
答:servlet有良好的生存期的定义,包括加载和实例化、初始化、处理请求以及服务结束。这个生存期由javax.servlet.Servlet接口的init,service和destroy方法表达。


62、解释一下什么是servlet;
答:servlet有良好的生存期的定义,包括加载和实例化、初始化、处理请求以及服务结束。这个生存期由javax.servlet.Servlet接口的init,service和destroy方法表达。
1、说一说Servlet的生命周期? 
答:servlet有良好的生存期的定义,包括加载和实例化、初始化、处理请求以及服务结束。这个生存期由javax.servlet.Servlet接口的init,service和destroy方法表达。


Servlet被服务器实例化后,容器运行其init方法,请求到达时运行其service方法,service方法自动派遣运行与请求对应的doXXX方法(doGet,doPost)等,当服务器决定将实例销毁的时候调用其destroy方法。
web容器加载servlet,生命周期开始。通过调用servlet的init()方法进行servlet的初始化。通过调用service()方法实 现,根据请求的不同调用不同的do***()方法。结束服务,web容器调用servlet的destroy()方法。


4、Servlet的基本架构 
public class ServletName extends HttpServlet { 
public void doPost(HttpServletRequest request, HttpServletResponse response) throws 
ServletException, IOException { 

public void doGet(HttpServletRequest request, HttpServletResponse response) throws 
ServletException, IOException { 


3、SERVLET API中forward() 与redirect()的区别? 
答:前者仅是容器中控制权的转向,在客户端浏览器地址栏中不会显示出转向后的地址;后者则是完全的跳转,浏览器将会得到跳转的地址,并重新发送请求链接。 这样,从浏览器的地址栏中可以看到跳转后的链接地址。所以,前者更加高效,在前者可以满足需要时,尽量使用forward()方法,并且,这样也有助于隐 藏实际的链接。在有些情况下,比如,需要跳转到一个其它服务器上的资源,则必须使用
sendRedirect()方法。


60、什么情况下调用doGet()和doPost()? 
Jsp页面中的FORM标签里的method属性为get时调用doGet(),为post时调用doPost()。


66、Request对象的主要方法: 
setAttribute(String name,Object):设置名字为name的request的参数值 
getAttribute(String name):返回由name指定的属性值 
getAttributeNames():返回request对象所有属性的名字集合,结果是一个枚举的实例 
getCookies():返回客户端的所有Cookie对象,结果是一个Cookie数组 
getCharacterEncoding():返回请求中的字符编码方式 
getContentLength():返回请求的Body的长度 
getHeader(String name):获得HTTP协议定义的文件头信息 
getHeaders(String name):返回指定名字的request Header的所有值,结果是一个枚举的实例 
getHeaderNames():返回所以request Header的名字,结果是一个枚举的实例 
getInputStream():返回请求的输入流,用于获得请求中的数据 
getMethod():获得客户端向服务器端传送数据的方法 
getParameter(String name):获得客户端传送给服务器端的有name指定的参数值 
getParameterNames():获得客户端传送给服务器端的所有参数的名字,结果是一个枚举的实例 
getParametervalues(String name):获得有name指定的参数的所有值 
getProtocol():获取客户端向服务器端传送数据所依据的协议名称 
getQueryString():获得查询字符串 
getRequestURI():获取发出请求字符串的客户端地址 
getRemoteAddr():获取客户端的IP地址 
getRemoteHost():获取客户端的名字 
getSession([Boolean create]):返回和请求相关Session 
getServerName():获取服务器的名字 
getServletPath():获取客户端所请求的脚本文件的路径 
getServerPort():获取服务器的端口号 
removeAttribute(String name):删除请求中的一个属性


19、forward 和redirect的区别 
forward是服务器请求资源,服务器直接访问目标地址的URL,把那个URL的响应内容读取过来,然后把这些内容再发给浏览器,浏览器根本不知道服务器发送的内容是从哪儿来的,所以它的地址栏中还是原来的地址。 
redirect就是服务端根据逻辑,发送一个状态码,告诉浏览器重新去请求那个地址,一般来说浏览器会用刚才请求的所有参数重新请求,所以session,request参数都可以获取。

4、request.getAttribute() 和 request.getParameter() 有何区别?


1. jsp有哪些内置对象?作用分别是什么? 分别有什么方法? 
答:JSP共有以下9个内置的对象: 
request 用户端请求,此请求会包含来自GET/POST请求的参数 
response 网页传回用户端的回应 
pageContext 网页的属性是在这里管理 
session 与请求有关的会话期 
application servlet 正在执行的内容 
out 用来传送回应的输出 
config servlet的构架部件 
page JSP网页本身 
exception 针对错误网页,未捕捉的例外


request表示HttpServletRequest对象。它包含了有关浏览器请求的信息,并且提供了几个用于获取cookie, header, 和session数据的有用的方法。 
response表示HttpServletResponse对象,并提供了几个用于设置送回 浏览器的响应的方法(如cookies,头信息等) 
out对象是javax.jsp.JspWriter的一个实例,并提供了几个方法使你能用于向浏览器回送输出结果。 
pageContext表示一个javax.servlet.jsp.PageContext对象。它是用于方便存取各种范围的名字空间、servlet相关的对象的API,并且包装了通用的servlet相关功能的方法。 
session表示一个请求的javax.servlet.http.HttpSession对象。Session可以存贮用户的状态信息 
applicaton 表示一个javax.servle.ServletContext对象。这有助于查找有关servlet引擎和servlet环境的信息 
config表示一个javax.servlet.ServletConfig对象。该对象用于存取servlet实例的初始化参数。 
page表示从该页面产生的一个servlet实例



2. jsp有哪些动作?作用分别是什么? 
(这个问题似乎不重要,不明白为何有此题)
答:JSP共有以下6种基本动作 
jsp:include:在页面被请求的时候引入一个文件。 
jsp:useBean:寻找或者实例化一个JavaBean。 
jsp:setProperty:设置JavaBean的属性。 
jsp:getProperty:输出某个JavaBean的属性。 
jsp:forward:把请求转到一个新的页面。 
jsp:plugin:根据浏览器类型为Java插件生成OBJECT或EMBED标记
59、JSP的常用指令 
isErrorPage(是否能使用Exception对象),isELIgnored(是否忽略表达式)


3. JSP中动态INCLUDE与静态INCLUDE的区别? 
答:动态INCLUDE用jsp:include动作实现 
<jsp:include page=included.jsp flush=true />它总是会检查所含文件中的变化,适合用于包含动态页面,并且可以带参数 静态INCLUDE用include伪码实现,定不会检查所含文件的变化,适用于包含静态页面 <%@ include file=included.htm %>



4、两种跳转方式分别是什么?有什么区别? 
(下面的回答严重错误,应该是想问forward和sendRedirect 的区别,毕竟出题的人不是专业搞文字艺术的人,可能表达能力并不见得很强,用词不一定精准,加之其自身的技术面也可能存在一些问题,不一定真正将他的意思 表达清楚了,严格意思上来讲,一些题目可能根本就无人能答,所以,答题时要掌握主动,只要把自己知道的表达清楚就够了,而不要去推敲原始题目的具体含义是 什么,不要一味想着是在答题)
答:有两种,分别为: 
<jsp:include page=included.jsp flush=true> 
<jsp:forward page= nextpage.jsp/> 
前者页面不会转向include所指的页面,只是显示该页的结果,主页面还是原来的页面。执行完后还会回来,相当于函数调用。并且可以带参数.后者完全转向新页面,不会再回来。相当于go to 语句。



63、页面间对象传递的方法 
request,session,application,cookie等 
64、JSP和Servlet有哪些相同点和不同点,他们之间的联系是什么? 
JSP是Servlet技术的扩展,本质上是Servlet的简易方式,更强调应用的外表表达。JSP编译后是"类servlet"。Servlet和 JSP最主要的不同点在于,Servlet的应用逻辑是在Java文件中,并且完全从表示层中的HTML里分离开来。而JSP的情况是Java和HTML 可以组合成一个扩展名为.jsp的文件。JSP侧重于视图,Servlet主要用于控制逻辑。


1、MVC的各个部分都有那些技术来实现?如何实现? 
答:MVC是Model-View-Controller的简写。Model 代表的是应用的业务逻辑(通过JavaBean,EJB组件实现), View 是应用的表示面(由JSP页面产生),Controller 是提供应用的处理过程控制(一般是一个Servlet),通过这种设计模型把应用逻辑,处理过程和显示逻辑分成不同的组件实现。这些组件可以进行交互和重 用。


68、我们在web应用开发过程中经常遇到输出某种编码的字符,如iso8859-1等,如何输出一个某种编码的字符串? 
Public String translate (String str) { 
String tempStr = ""; 
try { 
tempStr = new String(str.getBytes("ISO-8859-1"), "GBK"); 
tempStr = tempStr.trim(); 

catch (Exception e) { 
System.err.println(e.getMessage()); 

return tempStr; 

1.现在输入n个数字,以逗号,分开;然后可选择升或者降序排序;按提交键就在另一页面显示按什么排序,结果为,提供reset
7. 实际项目开发
1、在eclipse中调试时,怎样查看一个变量的值?
在要查看的变量前先设置断点,然后选中变量,右键选debug as-->Java Application,打开debug透视图,这时在Variables窗口中可以看到变量当前的值。
如果是局部变量,也可以在局部变量窗口中查看。
要知道一个方法被调用的方法调用链,可以在方法栈中查看。


2、你们公司使用的代码配置管理工具是什么? 
除了说以前使用cvs,现在新项目使用svn了,还简要说一下使用的过程,如果有可能,还说说仓库的概念和如何使用锁之类的细节。


3、你们的项目总金额多少,多少人开发,总共花了多少个月?
像巴巴运动网这种规模的项目,可以说是4、5个人、开发了4、5个月,费用则是4、50万。按每人每月两万收入去计算,就差不多了。


8. XML部分


1、xml有哪些解析技术?区别是什么? 
答:有DOM,SAX,STAX等 
DOM:处理大型文件时其性能下降的非常厉害。这个问题是由DOM的树结构所造成的,这种结构占用的内存较多,而且DOM必须在解析文件之前把整个文档装 入内存,适合对XML的随机访问SAX:不现于DOM,SAX是事件驱动型的XML解析方式。它顺序读取XML文件,不需要一次全部装载整个文件。当遇到 像文件开头,文档结束,或者标签开头与标签结束时,它会触发一个事件,用户通过在其回调事件中写入处理代码来处理XML文件,适合对XML的顺序访问 
STAX:Streaming API for XML (StAX) 
讲解这些区别是不需要特别去比较,就像说传智播客与其他培训机构的区别时,我们只需说清楚传智播客有什么特点和优点就行了,这就已经间接回答了彼此的区别。


2、你在项目中用到了xml技术的哪些方面?如何实现的? 
答:用到了数据存贮,信息配置两方面。在做数据交换平台时,将不能数据源的数据组装成XML文件,然后将XML文件压缩打包加密后通过网络传送给接收者, 接收解密与解压缩后再同XML文件中还原相关信息进行处理。在做软件配置时,利用XML可以很方便的进行,软件的各种配置参数都存贮在XML文件中。 
3、用jdom解析xml文件时如何解决中文问题?如何解析? 
答:看如下代码,用编码方式加以解决 

  1. package test;   
  2. import java.io.*;   
  3. public class DOMTest   
  4. {   
  5. private String inFile = "c:\\people.xml"   
  6. private String outFile = "c:\\people.xml"   
  7. public static void main(String args[])   
  8. {   
  9. new DOMTest();   
  10. }   
  11. public DOMTest()   
  12. {   
  13. try   
  14. {   
  15. javax.xml.parsers.DocumentBuilder builder =   
  16. javax.xml.parsers.DocumentBuilderFactory.newInstance().newDocumentBuilder();   
  17. org.w3c.dom.Document doc = builder.newDocument();   
  18. org.w3c.dom.Element root = doc.createElement("老师");   
  19. org.w3c.dom.Element wang = doc.createElement("王");   
  20. org.w3c.dom.Element liu = doc.createElement("刘");   
  21. wang.appendChild(doc.createTextNode("我是王老师"));   
  22. root.appendChild(wang);   
  23. doc.appendChild(root);   
  24. javax.xml.transform.Transformer transformer =   
  25. javax.xml.transform.TransformerFactory.newInstance().newTransformer();   
  26. transformer.setOutputProperty(javax.xml.transform.OutputKeys.ENCODING, "gb2312");   
  27. transformer.setOutputProperty(javax.xml.transform.OutputKeys.INDENT, "yes");   
  28. transformer.transform(new javax.xml.transform.dom.DOMSource(doc),   
  29. new   
  30. javax.xml.transform.stream.StreamResult(outFile));   
  31. }   
  32. catch (Exception e)   
  33. {   
  34. System.out.println (e.getMessage());   
  35. }   
  36. }   
  37. }   

4、编程用JAVA解析XML的方式. 

答:用SAX方式解析XML,XML文件如下: 

  1. <?xml version=1.0 encoding=gb2312?>   
  2. <person>   
  3. <name>王小明</name>   
  4. <college>信息学院</college>   
  5. <telephone>6258113</telephone>   
  6. <notes>男,1955年生,博士,95年调入海南大学</notes>   
  7. </person>   
事件回调类SAXHandler.java 

  1. import java.io.*;   
  2. import java.util.Hashtable;   
  3. import org.xml.sax.*;   
  4. public class SAXHandler extends HandlerBase   
  5. {   
  6. private Hashtable table = new Hashtable();   
  7. private String currentElement = null;   
  8. private String currentValue = null;   
  9. public void setTable(Hashtable table)   
  10. {   
  11. this.table = table;   
  12. }   
  13. public Hashtable getTable()   
  14. {   
  15. return table;   
  16. }   
  17. public void startElement(String tag, AttributeList attrs)   
  18. throws SAXException   
  19. {   
  20. currentElement = tag;   
  21. }   
  22. public void characters(char[] ch, int start, int length)   
  23. throws SAXException   
  24. {   
  25. currentValue = new String(ch, start, length);   
  26. }   
  27. public void endElement(String name) throws SAXException   
  28. {   
  29. if (currentElement.equals(name))   
  30. table.put(currentElement, currentValue);   
  31. }  
  32.   
  33. }   

JSP内容显示源码,SaxXml.jsp: 

  1. <HTML>   
  2. <HEAD>   
  3. <TITLE>剖析XML文件people.xml</TITLE>   
  4. </HEAD>   
  5. <BODY>   
  6. <%@ page errorPage=ErrPage.jsp   
  7. contentType=text/html;charset=GB2312 %>   
  8. <%@ page import=java.io.* %>   
  9. <%@ page import=java.util.Hashtable %>   
  10. <%@ page import=org.w3c.dom.* %>   
  11. <%@ page import=org.xml.sax.* %>   
  12. <%@ page import=javax.xml.parsers.SAXParserFactory %>   
  13. <%@ page import=javax.xml.parsers.SAXParser %>   
  14. <%@ page import=SAXHandler %>   
  15. <%   
  16. File file = new File(c:\people.xml);   
  17. FileReader reader = new FileReader(file);   
  18. Parser parser;   
  19. SAXParserFactory spf = SAXParserFactory.newInstance();   
  20. SAXParser sp = spf.newSAXParser();   
  21. SAXHandler handler = new SAXHandler();   
  22. sp.parse(new InputSource(reader), handler);   
  23. Hashtable hashTable = handler.getTable();   
  24. out.println(<TABLE BORDER=2><CAPTION>教师信息表</CAPTION>);   
  25. out.println(<TR><TD>姓名</TD> + <TD> +   
  26. (String)hashTable.get(new String(name)) + </TD></TR>);   
  27. out.println(<TR><TD>学院</TD> + <TD> +   
  28. (String)hashTable.get(new String(college))+</TD></TR>);   
  29. out.println(<TR><TD>电话</TD> + <TD> +   
  30. (String)hashTable.get(new String(telephone)) + </TD></TR>);   
  31. out.println(<TR><TD>备注</TD> + <TD> +   
  32. (String)hashTable.get(new String(notes)) + </TD></TR>);   
  33. out.println(</TABLE>);   
  34. %>   
  35. </BODY>   
  36. </HTML>   

70、XML文档定义有几种形式?它们之间有何本质区别?解析XML文档有哪几种方式? 
a: 两种形式 dtd schema,

b: 本质区别:schema本身是xml的,可以被XML解析器解析(这也是从DTD上发展schema的根本目的),c:有DOM,SAX,STAX等 
DOM:处理大型文件时其性能下降的非常厉害。这个问题是由DOM的树结构所造成的,这种结构占用的内存较多,而且DOM必须在解析文件之前把整个文档装入内存,适合对XML的随机访问 
SAX:不现于DOM,SAX是事件驱动型的XML解析方式。它顺序读取XML文件,不需要一次全部装载整个文件。当遇到像文件开头,文档结束,或者标签开头与标签结束时,它会触发一个事件,用户通过在其回调事件中写入处理代码来处理XML文件,适合对XML的顺序访问 
STAX:Streaming API for XML (StAX)

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多