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

本文介绍了一个Java程序设计案例,包括数组的排序及平均数计算,同时演示了如何构建一个非二叉树的树形结构并实现节点的递归搜索。
题目:
排序,在命令行接受用户输入的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 次评分)





 
本指南详细阐述基于Python编程语言结合OpenCV计算机视觉库构建实时眼部状态分析系统的技术流程。该系统能够准确识别眼部区域,并对眨眼动作与持续闭眼状态进行判别。OpenCV作为功能强大的图像处理工具库,配合Python简洁的语法特性与丰富的第三方模块支持,为开发此类视觉应用提供了理想环境。 在环境配置阶段,除基础Python运行环境外,还需安装OpenCV核心模块与dlib机器学习库。dlib库内置的HOG(方向梯度直方图)特征检测算法在面部特征定位方面表现卓越。 技术实现包含以下关键环节: - 面部区域检测:采用预训练的Haar级联分类器或HOG特征检测器完成初始人脸定位,为后续眼部分析建立基础坐标系 - 眼部精确定位:基于已识别的人脸区域,运用dlib提供的面部特征点预测模型准确标定双眼位置坐标 - 眼睑轮廓分析:通过OpenCV的轮廓提取算法精确勾勒眼睑边缘形态,为状态判别提供几何特征依据 - 眨眼动作识别:通过连续帧序列分析眼睑开合度变化,建立动态阈值模型判断瞬时闭合动作 - 持续闭眼检测:设定更严格的状态持续时间与闭合程度双重标准,准确识别长时间闭眼行为 - 实时处理架构:构建视频流处理管线,通过帧捕获、特征分析、状态判断的循环流程实现实时监控 完整的技术文档应包含模块化代码实现、依赖库安装指引、参数调优指南及常见问题解决方案。示例代码需具备完整的错误处理机制与性能优化建议,涵盖图像预处理、光照补偿等实际应用中的关键技术点。 掌握该技术体系不仅有助于深入理解计算机视觉原理,更为疲劳驾驶预警、医疗监护等实际应用场景提供了可靠的技术基础。后续优化方向可包括多模态特征融合、深度学习模型集成等进阶研究领域。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
本项目是一个基于STM32的人脸识别系统,利用OPENCV库进行图像处理,采用QT作为图形界面开发。该系统具备人脸采集、图片训练、数据库管理及人脸识别等功能,能够长时间稳定运行,并提供了统一的接口以便进行二次开发。 功能特点 人脸采集:系统能够从视频图像中采集人脸数据。 图片训练:通过提取人脸特征进行训练,提高识别准确性。 数据库管理:管理人脸数据,便于后续的识别和处理。 人脸识别:实现对人脸的检测与识别,适用于多种应用场景。 技术原理 本系统采用基于OPENCV的级联分类检测器,通过视频图像提取人脸特征进行训练。主要技术包括: 光线补偿技术:对图像进行补光处理,提高图像质量。 高斯平滑技术:消除图像噪声,提升图像清晰度。 二值化技术:采用局部阈值进行二值化处理,便于后续的人脸定位和特征提取。 应用场景 人脸识别技术在图像处理与视频检索、视频监控、视频显示等方面具有广泛的应用。本系统适用于以下场景: 安全监控:在公共场所进行人脸识别,提高安全监控效率。 身份验证:用于门禁系统、考勤系统等身份验证场景。 智能交互:在智能家居、智能终端等设备中实现人脸识别交互。 开发环境 硬件平台:STM32微控制器 软件平台:OPENCV库、QT图形界面开发工具 使用说明 环境搭建:确保STM32开发环境及OPENCV、QT库已正确安装。 代码编译:按照提供的Makefile文件进行代码编译。 系统运行:将编译后的程序烧录到STM32开发板,启动系统。 功能测试:通过QT界面进行人脸采集、训练和识别功能测试。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值