北京创新维信公司笔试题 + 本人答案

题目:
排序,在命令行接受用户输入的N个数字, 以-1作为结束标志,并且-1不计算在内,对这些输入的数字进行排序输出,并计算平均数。
要求 1. 自己写排序算法(冒泡,选择等等任选),不用汉字,拼音做类名,注释等等。
2. 也可以不从命令行输入, 而是直接对数组排序.


创建树,树上每一个节点都是Class Node的实例,Node有name, value属性,其中name和value是初始时已经设好的, 要求用数据结构中的树(不是二叉树)来实现,要求能够保持构造树时添加结点的顺序。构造树的时候可以在代码中写死各个节点值,不用动态输入进行构造树,不用汉字,拼音做类名,注释等等(用递归实现)
要求
1. 写一个方法Node searchNode(String searchName),实现节点查找. 要求在树中查找name值等于searchName的节点,如果找不到,返回NULL, 找到了就返回此节点.
2. 调用searchNode方法查找节点,没有找到节点输出"Not found", 如果找到了就输出此节点name,value值。
构造如下的树,查找节点 Sub 22, Sub 3, Sub 10(找不到)
依次调用
searchNode("Sub 22");
输出 Sub 22, 0
searchNode("Sub 3");
输出 Sub 3, 50
searchNode("Sub 10");
输出 Not found

Root(value:0)--
|--Sub 1 (value:20)
|--Sub 2(value:10)
| |--
| |--Sub 21(value:5)
| |--Sub 22 (value:0)
|--Sub 3 (value:50)
|--
|--Sub 31(value:100)
|--Sub 32(value:200)



我做的程序:


public class ArraySort {

public static void main(String[] args) {
if(args.length == 0){ //estimate the input running arguments
System.out.println("The parameter must be numbers and had better ends with -1 , such as ' java ArraySort 1 34 -1 '");
return;
}
int[] array = generateArray(args);
getAverage(array);
selectionSort(array);
print(array);
}

private static double getAverage(int[] array) {
//get average
double average = 0;
int sum = 0;
for(int i=0; i<array.length; i++){
sum += array[i];
}
average = ((double)sum) / array.length;
System.out.println("The average of the array is " + average);
return average;
}

private static void print(int[] array) {
//print the array
System.out.print("The memebers of the array are : ");
for(int i=0; i><array.length; i++){
System.out.print(array[i] + " ");
}

}

private static int[] generateArray(String[] args) {
// parse String[] to int[]
int temp = 0; //temporarily deposit the parse int
int arraysize = args.length; //deposite the length of the array ,init value = args.length

for(int i=0; i><args.length; i++){ //get the size before "-1"
try{
temp = Integer.parseInt(args[i]);
if(temp == -1){
arraysize = i;
break;
}
}catch(NumberFormatException e){
System.out.println("The parameter must be numbers and had better ends with -1 , such as ' java ArraySort 1 34 -1 '");
System.exit(-1);
}
}

int[] array = new int[arraysize]; //generate the array ,size use the parameter : arraysize
for(int i=0; i><arraysize; i++){
array[i] = Integer.parseInt(args[i]);
}
return array;

}

public static void selectionSort(int[] array){
//selection sort
int flag, temp; //the flag is used to deposit the current smaller number's position
for(int i=0; i><array.length; i++){
flag = i;
for(int j=i+1; j><array.length; j++){
if(array[j] >< array[flag]){
flag = j; //update the smaller number's position
}
}
if(flag != i){ //swap
temp = array[i];
array[i] = array[flag];
array[flag] = temp;
}
}
}
}






import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

public class Node {
private String name;
private int value;
public List<Node> list; // use jdk5.0's generic

public Node(String name, int value){ //constructor
this.name = name;
this.value = value;
}

public Node searchNode(String searchName) { //the method of searchnode use recursion
if (this.getName().equals(searchName))
return this;

Node node = null;
Iterator<Node> iterator = list.iterator();
while (iterator.hasNext()) {
node = iterator.next();
if (searchName.equals(node.getName()))
return node;
else if (node.list != null)
node.searchNode(searchName); //recursion
}
System.out.println("Not found");
return null;
}

public void addSubNode(String name, int value) { //add sub node
if (list == null){
list = new ArrayList<Node>();
}
Node node = new Node(name, value); //use the constuctor
list.add(node);
}

public String toString() { //override the toString method
return name + ", " + value;
}

public String getName() { //generate getters and setters
return name;
}

public void setName(String name) { //generate getters and setters
this.name = name;
}

public int getValue() { //generate getters and setters
return value;
}

public void setValue(int value) { //generate getters and setters
this.value = value;
}

public static void print(Node n){ //print method , use the overrided toString method
if(n != null){
System.out.println(n);
}
}

public static void main(String[]args){
Node n = new Node("Root", 0); //generate Root node
n.addSubNode("Sub 1", 20); //insert node
n.addSubNode("Sub 2", 10);
n.addSubNode("Sub 21", 5);
n.addSubNode("Sub 22", 0);
n.addSubNode("Sub 3", 50);
n.addSubNode("Sub 31", 100);
n.addSubNode("Sub 32", 200);

print(n.searchNode("Sub 22")); //print the result of search
print(n.searchNode("Sub 3"));
print(n.searchNode("Sub 10"));

}

}

<script src="/dwr/interface/Rate.js" type="text/javascript"></script> <script src="/dwr/engine.js" type="text/javascript"></script> <script src="/dwr/util.js" type="text/javascript"></script> <script language="JavaScript" src="/js/prototype/prototype.js" type="text/javascript"></script> <script language="JavaScript" src="/js/events.js" type="text/javascript"></script> <script language="JavaScript" src="/js/scriptaculous/scriptaculous.js" type="text/javascript"></script> <script src="/js/scriptaculous/builder.js" type="text/javascript"></script> <script src="/js/scriptaculous/effects.js" type="text/javascript"></script> <script src="/js/scriptaculous/dragdrop.js" type="text/javascript"></script> <script src="/js/scriptaculous/controls.js" type="text/javascript"></script> <script src="/js/scriptaculous/slider.js" type="text/javascript"></script> <script type="text/javascript"> var userRating = 0; var inProgress = false; var RateInclude = { update: function() { Rate.getMeanRating('1', '3806', { callback:function(data) { RateInclude.updateMeanRating(data); } }); Rate.getRatingCount('1', '3806', { callback:function(data) { RateInclude.updateRatingCount(data); } }); Rate.getUserRating('1', '3806', { callback:function(data) { RateInclude.updateUserRating(data); } }); }, updateMeanRating: function(data) { // change the title of the span to reflect the new mean rating $('jive-content-avgrating-score').title = '<@ww.text name="rate.avg_user_rating.label"/> ' + data; // loop though each mean rating icon and change according to the new mean rating if (data >= 1) { $('jive-icon-avgrating-1').className = 'jive-icon-avgrating-on'; } else if (data >= (1 - 0.50)) { $('jive-icon-avgrating-1').className = 'jive-icon-avgrating-half' } else { $('jive-icon-avgrating-1').className = 'jive-icon-avgrating-off' } if (data >= 2) { $('jive-icon-avgrating-2').className = 'jive-icon-avgrating-on'; } else if (data >= (2 - 0.50)) { $('jive-icon-avgrating-2').className = 'jive-icon-avgrating-half' } else { $('jive-icon-avgrating-2').className = 'jive-icon-avgrating-off' } if (data >= 3) { $('jive-icon-avgrating-3').className = 'jive-icon-avgrating-on'; } else if (data >= (3 - 0.50)) { $('jive-icon-avgrating-3').className = 'jive-icon-avgrating-half' } else { $('jive-icon-avgrating-3').className = 'jive-icon-avgrating-off' } if (data >= 4) { $('jive-icon-avgrating-4').className = 'jive-icon-avgrating-on'; } else if (data >= (4 - 0.50)) { $('jive-icon-avgrating-4').className = 'jive-icon-avgrating-half' } else { $('jive-icon-avgrating-4').className = 'jive-icon-avgrating-off' } if (data >= 5) { $('jive-icon-avgrating-5').className = 'jive-icon-avgrating-on'; } else if (data >= (5 - 0.50)) { $('jive-icon-avgrating-5').className = 'jive-icon-avgrating-half' } else { $('jive-icon-avgrating-5').className = 'jive-icon-avgrating-off' } }, updateRatingCount: function(data) { // update the rating count based on the new rating var ratingString = (data == 1) ? '评分' : '评分'; $('jive-content-avgrating-count').innerHTML= '(' + data + ' ' + ratingString + ')'; }, updateUserRating: function(data) { // set the javascript variable userRating to the new user rating value userRating = data; // reload the user rating RateInclude.showUserRating(data); }, addRating: function(score) { inProgress = true; var objectType = '1'; var objectID = '3806'; // hide user rating $('jive-content-userrating-score').style.display = 'none'; // show saving message $('jive-content-userrating-saved').innerHTML = '正在保存...'; $('jive-content-userrating-saved').style.display = ''; // dwr call to add rating Rate.addRating(objectType, objectID, score, { callback:function() { RateInclude.update(); // changed saving message to saved $('jive-content-userrating-saved').innerHTML = '已经保存.'; // hide saved message Effect.Fade('jive-content-userrating-saved', {afterFinish:RateInclude.testShow}); inProgress = false; } }); }, testShow: function() { $('jive-content-userrating-score').style.display = ''; }, showUserRating: function(score) { if (score == 0 || inProgress) { $('jive-content-userrating-desc').innerHTML = ''; } if (score >= 1) { $('jive-icon-userrating-1').className = 'jive-icon-userrating-on'; if (score == 1) { $('jive-content-userrating-desc').innerHTML = '很差'; } } else { $('jive-icon-userrating-1').className = 'jive-icon-userrating-off' } if (score == 0 || inProgress) { $('jive-content-userrating-desc').innerHTML = ''; } if (score >= 2) { $('jive-icon-userrating-2').className = 'jive-icon-userrating-on'; if (score == 2) { $('jive-content-userrating-desc').innerHTML = '较差'; } } else { $('jive-icon-userrating-2').className = 'jive-icon-userrating-off' } if (score == 0 || inProgress) { $('jive-content-userrating-desc').innerHTML = ''; } if (score >= 3) { $('jive-icon-userrating-3').className = 'jive-icon-userrating-on'; if (score == 3) { $('jive-content-userrating-desc').innerHTML = '一般'; } } else { $('jive-icon-userrating-3').className = 'jive-icon-userrating-off' } if (score == 0 || inProgress) { $('jive-content-userrating-desc').innerHTML = ''; } if (score >= 4) { $('jive-icon-userrating-4').className = 'jive-icon-userrating-on'; if (score == 4) { $('jive-content-userrating-desc').innerHTML = '不错'; } } else { $('jive-icon-userrating-4').className = 'jive-icon-userrating-off' } if (score == 0 || inProgress) { $('jive-content-userrating-desc').innerHTML = ''; } if (score >= 5) { $('jive-icon-userrating-5').className = 'jive-icon-userrating-on'; if (score == 5) { $('jive-content-userrating-desc').innerHTML = '很好'; } } else { $('jive-icon-userrating-5').className = 'jive-icon-userrating-off' } } }; </script>
平均得分
(0 次评分)





 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值