BUPT2012网研院机试Java题解

2024-03-09 00:10

本文主要是介绍BUPT2012网研院机试Java题解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目搜集于各位前辈,侵删。

第一题

在这里插入图片描述
在这里插入图片描述

import java.util.Scanner;public class i1201 {public static void main(String[] args) {// TODO Auto-generated method stubScanner sc = new Scanner(System.in);int T = sc.nextInt();for(int t=0;t<T;t++) {char c = sc.next().charAt(0);String s = sc.next();int sum = 0;for(int i = 0;i<s.length();i++) {if(s.charAt(i)==c) {sum++;}}System.out.println(sum);}sc.close();}}

第二题

在这里插入图片描述
在这里插入图片描述

import java.util.ArrayList;
import java.util.LinkedList;
import java.util.Queue;
import java.util.Scanner;public class i1202 {static Node root = null;public static void main(String[] args) {// TODO Auto-generated method stubScanner sc = new Scanner(System.in);int T = sc.nextInt();for(int t=0;t<T;t++) {int n = sc.nextInt();int m = sc.nextInt();root = new Node(1,1);for(int i=0;i<n;i++) {int s = sc.nextInt();int f = sc.nextInt();Node father = search(f);Node son = new Node(s,father.depth+1);father.sons.add(son);}int depth = 1;int first = 1;Queue<Node> q = new LinkedList<Node>();q.add(root);while(q.size()!=0) {Node node = q.remove();if(node.depth==depth) {if(first == 1) {System.out.print(node.value);first = 0;}else {System.out.print(" "+node.value);}					}else {depth = node.depth;System.out.println();System.out.print(node.value);first = 0;}for(int i = 0;i<node.sons.size();i++) {q.add(node.sons.get(i));}}}sc.close();}static class Node{int value;ArrayList<Node> sons = new ArrayList<Node>();int depth;public Node(int value, int depth) {super();this.value = value;this.depth = depth;}}static Node search(int value) {Queue<Node> q = new LinkedList<Node>();q.add(root);while(q.size()!=0) {Node n = q.remove();if(n.value == value) {return n;}else {for(int i = 0;i<n.sons.size();i++) {q.add(n.sons.get(i));}}}return null;}}

第三题

在这里插入图片描述
在这里插入图片描述

import java.util.Scanner;public class i1203 {public static void main(String[] args) {// TODO Auto-generated method stubScanner sc = new Scanner(System.in);int T = sc.nextInt();for(int t=0;t<T;t++) {String s = sc.next();if(ok(s)) {System.out.println("Yes");}else {System.out.println("No");}}sc.close();}static boolean ok(String s) {String[] ss = s.split("\\.");if(ss.length!=4) {return false;}for(int i = 0;i<ss.length;i++) {int a = Integer.parseInt(ss[i]);if(a>=0&&a<=255) {}else {return false;}}return true;}
}

第四题

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

import java.util.Scanner;
//太懒了没跑代码,思路比较暴力,就是全排列然后依次比较
public class i1204 {static double max = 0;static double maxx = 0;static double maxy = 0;public static void main(String[] args) {// TODO Auto-generated method stubScanner sc = new Scanner(System.in);int T = sc.nextInt();for(int t=0;t<T;t++) {int n = sc.nextInt();Order[] order = new Order[n];for(int i = 0;i<n;i++) {String op = sc.next();int x = sc.nextInt();Order o = new Order(op,x);order[i] = o;}perm(order,0,order.length-1);System.out.println(max);}System.out.println(maxx+"."+maxy);sc.close();}static class Order{String op;int x;public Order(String op, int x) {super();this.op = op;this.x = x;}}static void perm(Order[] order,int a,int b) {if(a==b) {calculate(order);}else {for(int i = a;i<=b;i++) {Order temp = order[a];order[a] = order[i];order[i] = temp;perm(order,a+1,b);temp = order[a];order[a] = order[i];order[i] = temp;}}}static void calculate(Order[] order){double x=0;double y=0;int dir=0;for(int i=0;i<order.length;i++) {Order o = order[i];if(o.op.equals("left")) {dir+=o.x;if(dir>=360) {dir-=360;}}else if(o.op.equals("right")) {dir-=o.x;if(dir<0) {dir+=360;}}else if(o.op.equals("forward")) {double disx = Math.cos(dir)*o.x;double disy = Math.sin(dir)*o.x;x+=disx;y+=disy;}else {double disx = Math.cos(dir)*o.x;double disy = Math.sin(dir)*o.x;x-=disx;y-=disy;}}double dis = Math.sqrt(x*x+y*y);if(dis>max) {max = dis;maxx = x;maxy = y;}}
}

这篇关于BUPT2012网研院机试Java题解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/788884

相关文章

Spring Boot循环依赖原理、解决方案与最佳实践(全解析)

《SpringBoot循环依赖原理、解决方案与最佳实践(全解析)》循环依赖指两个或多个Bean相互直接或间接引用,形成闭环依赖关系,:本文主要介绍SpringBoot循环依赖原理、解决方案与最... 目录一、循环依赖的本质与危害1.1 什么是循环依赖?1.2 核心危害二、Spring的三级缓存机制2.1 三

在Spring Boot中浅尝内存泄漏的实战记录

《在SpringBoot中浅尝内存泄漏的实战记录》本文给大家分享在SpringBoot中浅尝内存泄漏的实战记录,结合实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录使用静态集合持有对象引用,阻止GC回收关键点:可执行代码:验证:1,运行程序(启动时添加JVM参数限制堆大小):2,访问 htt

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

浅析Java中如何优雅地处理null值

《浅析Java中如何优雅地处理null值》这篇文章主要为大家详细介绍了如何结合Lambda表达式和Optional,让Java更优雅地处理null值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录场景 1:不为 null 则执行场景 2:不为 null 则返回,为 null 则返回特定值或抛出异常场景

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

SpringBoot条件注解核心作用与使用场景详解

《SpringBoot条件注解核心作用与使用场景详解》SpringBoot的条件注解为开发者提供了强大的动态配置能力,理解其原理和适用场景是构建灵活、可扩展应用的关键,本文将系统梳理所有常用的条件注... 目录引言一、条件注解的核心机制二、SpringBoot内置条件注解详解1、@ConditionalOn

通过Spring层面进行事务回滚的实现

《通过Spring层面进行事务回滚的实现》本文主要介绍了通过Spring层面进行事务回滚的实现,包括声明式事务和编程式事务,具有一定的参考价值,感兴趣的可以了解一下... 目录声明式事务回滚:1. 基础注解配置2. 指定回滚异常类型3. ​不回滚特殊场景编程式事务回滚:1. ​使用 TransactionT

Spring LDAP目录服务的使用示例

《SpringLDAP目录服务的使用示例》本文主要介绍了SpringLDAP目录服务的使用示例... 目录引言一、Spring LDAP基础二、LdapTemplate详解三、LDAP对象映射四、基本LDAP操作4.1 查询操作4.2 添加操作4.3 修改操作4.4 删除操作五、认证与授权六、高级特性与最佳