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

本文介绍了一个Java程序设计案例,包括数组的排序及平均数计算,同时演示了如何构建一个非二叉树的树形结构并实现节点的递归搜索。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目:
排序,在命令行接受用户输入的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"));

}

}

平均得分
(0 次评分)





 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值