热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

笔试强训(二十六)

目录一、选择题二、编程题2.1快到碗里来2.1.1题目2.1.2题解2.2跳台阶扩展问题2.2.1题目2.2.2题解一、选择题(1)下列哪些语句关于内




目录


  • 一、选择题
  • 二、编程题
    • 2.1 快到碗里来
      • 2.1.1 题目
      • 2.1.2 题解

    • 2.2 跳台阶扩展问题
      • 2.2.1 题目
      • 2.2.2 题解





一、选择题

(1)下列哪些语句关于内存回收的说明正确的是(B)
A.程序员必须创建一个线程来释放内存
B.内存回收程序负责释放无用内存
C.内存回收程序允许程序员直接释放内存
D.内存回收程序可以在指定的时间内释放内存对象



A. C.D JVM垃圾回收由JVM自己执行,我们没有权限回收内存,何时释放也是不知道的


(2)在java7中,下列哪个说法是正确的(D)
A.ConcurrentHashMap使用synchronized关键字保证线程安全
B.HashMap实现了Collection接口
C.Arrays.asList方法返回java.util.ArrayList对象
D.SimpleDateFormat对象是线程不安全的



A.ConcurrentHashMap使用lock锁保证线程安全
B. HashMap没有实现Collection接口,实现的是Map接口,Collection是线性表的顶级接口
C. 返回的是List接口对象
在这里插入图片描述



二、编程题

2.1 快到碗里来


2.1.1 题目

在这里插入图片描述


2.1.2 题解

思路:由于题目给出的n (1≤n≤2^128) 和r (1≤r≤2^128)的数据范围太大,无法用基类型来存储,因此需要使用BigDecimal来进行存储

代码:

public static void main(String[] args){

Scanner scanner=new Scanner(System.in);
while(scanner.hasNextBigInteger()){
BigDecimal n=scanner.nextBigDecimal();
BigDecimal r=scanner.nextBigDecimal();
BigDecimal len=r.multiply(new BigDecimal("6.28"));
if(n.compareTo(len)==1){
System.out.println("No");
}else {
System.out.println("Yes");
}
}
}

2.2 跳台阶扩展问题


2.2.1 题目

在这里插入图片描述


2.2.2 题解

思路:题目说,一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级

一个阶的时候 f(1) = 1 ; 两个阶的时候可以有 f(2) = 1+f(1)=2; 三个阶的时候可以有 f(3) =1+f(2)+f(1)=4;

总跳法为: f(n) = 1+f(n-1) + f(n-2)+…+f(1) (第一个1是跳n阶只有一种方法)
依次类推,得到类推公式有n阶时:f(n)=2^(n-1)

代码:

public int jumpFloorII(int target) {
if(target<0){
return -1;
}else if(target&#61;&#61;1){
return 1;
}else {
return 2*jumpFloorII(target-1);
}
}






推荐阅读
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • Python 异步编程:深入理解 asyncio 库(上)
    本文介绍了 Python 3.4 版本引入的标准库 asyncio,该库为异步 IO 提供了强大的支持。我们将探讨为什么需要 asyncio,以及它如何简化并发编程的复杂性,并详细介绍其核心概念和使用方法。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • c# – UWP:BrightnessOverride StartOverride逻辑 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
  • 本章将深入探讨移动 UI 设计的核心原则,帮助开发者构建简洁、高效且用户友好的界面。通过学习设计规则和用户体验优化技巧,您将能够创建出既美观又实用的移动应用。 ... [详细]
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
  • 本文详细介绍了macOS系统的核心组件,包括如何管理其安全特性——系统完整性保护(SIP),并探讨了不同版本的更新亮点。对于使用macOS系统的用户来说,了解这些信息有助于更好地管理和优化系统性能。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
author-avatar
MR付的世界
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有