编程语言:Java

 2019年全国高校计算机能力挑战赛分设大数据算法赛(所谓的内部试题)

一、选择题(共15题,每题3分,共45分)

1. 在Java中下列说法正确的是(  )

A、一个子类可以有多个父类,一个父类也可以有多个子类

B、一个子类可以有多个父类,但一个父类只可以有一个子类

C、 一个子类可以有一个父类,但一个父类可以有多个子类

D、上述说法都不对

2. 关于Java垃圾回收机制描述不正确的是(   )

A、垃圾回收机制不须通过程序调用相应方法,也能自动启动。

B、Java程序用System.gc()方法一定能进行垃圾回收;

C、垃圾回收机制属于jvm自动操作,java程序可以不进行垃圾回收操作。

D、垃圾回收机制并不是由操作系统自动执行。

3. 面向对象技术领域内占主导地位的标准建模语言是(    )

A、C++  B、Java    C、C#   D、UML

4. 在Java语言中,以下(  )不属于基本数据类型。

A、 int    B、boolean    C、 String    D、 double

5.  Java语言类间的继承关系是(  )。

A、单继承 B、多重继承   C、不能继承    D、不一定

6. 以下关于构造方法的描述正确的是(  )。

A、构造方法的返回类型只能是void型。

B、构造方法是类的一种特殊函数,它的方法名必须与类名相同。

C、构造方法的主要作用是完成对类的对象的初始化工作。

D、一般在创建新对象时,系统会自动调用构造方法。

7.  下列关于java的运行环境说法错误的是  (    )。

A、CLASSPATH为Java加载类(class or lib)路径。

B、Java.exe是用来解释执行Java类文件。

C、 JAVA_HOME的作用是指明JDK的安装路径,例如可以设置成C:\Program Files\Java\jdk1.6.0_01。

D、 Java 语言编写的程序是与平台无关,所以不须要配置java的运行环境。

8. 下面的选项中,哪些项不属于“汽车类”的属性(  )。

A、品牌      B、刹车       C、价格        D、速度

9. 下列两个物品之间的关系不属于继承关系的是( )

A、卡和银行卡    B、汽车和轮胎   C、人和学生     D、动物和狗

10. 下列两个名词之间的关系符合类和对象关系的是(    )

A、交通工具和电动小汽车   B、警犬和牧羊犬

C、楼房和房间             D、图书馆和图书

11.关于字符串,下列代码书写不正确的是(  )
A、 String str = new String();

B、 String str = “Hello”+“ACCP”;
C、 String str = “123”+“Hello World!”;
D、 StringBuffer strBuf = new StringBuffer(“Hello World!”);
    String str = strBuf;

12. 下列选项中关于Java中super关键字的说法错误的是(   )。

A、super关键字是在子类对象内部指代其父类对象的引用

B、super关键字不仅可以指代子类的直接父类,还可以指代父类的父类

C、子类可以通过super关键字调用父类的方法

D、子类可以通过super关键字调用父类的属性

13. 下列Java代码写法错误的是(  )

class Pet{      }

class Dog extends Pet{}

class Test{

public static void t(Pet p){}

}

A、Pet p = new Pet(); Test.t(p);     B、Pet p = new Dog(); Test.t(p);

C、Dog p = new Dog(); Test.t(p);     D、Dog p = new Pet(); Test.t(p);

14. 关于下列代码说法正确的是(    )。

public class Test{

public void a(){}

public void a(int i){}

public int  a(){}

}

A、上述三个a方法是方法重载

B、上述三个a方法是方法重写

C、上面代码编译通不过

D、上述三个方法是第一个和第二个a方法是方法的重写,第三个a方法编译会有问题。

15. 如果一个类的文件名为Student.java,类的代码为:

public class  Student {

public static void main(String[] args) {

System.out.println(4<<2);

}}

下列说法正确的是:(    )

A、程序运行结果为1;    B、程序运行结果为2;

C、程序运行结果为16;   D、程序编译错误,不能运行;

二、程序设计题(5道题,共55分)

1.(10分) 统计1到N以内质数的个数,并输出这个数目。

输入说明:一个整数N;

输出说明:质数的数量

输入样例:12

输出样例:5

public class Main {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
int n = input.nextInt();
System.out.println(getResult1(n));
} private static int getResult1(int n) {
int cot = 0;
for (int i = 2; i <= n; i++) {
if (isPrime(i)) {
cot++;
}
}
return cot;
}
private static boolean isPrime(int n) {
boolean flag=true;
for (int i = 2; i < n; i++) {
if(n%i==0) {
flag=false;
}
}
return flag;
}
private static int getResult(int n) {
int cot=0;
boolean [] flag=new boolean[n+1];
Arrays.fill(flag, true);
for (int i = 2; i <n; i++) {
if(flag[i]) {
cot++;
for (int j = i*2; j < n; j+=i) {
flag[j]=false;
}
}
}
return cot;
}
}

2.(10分) 某汽车组装厂主要产品为4轮沙滩越野车(3座)和6轮山地越野车(5座),这两类车辆的轮胎是通用的,车内安装的座位也是通用的。这些部件每月初由供货商送到仓库,其它所需部件都有足够多的库存。组装厂依据月初仓库中的合格部件数量决定每类车辆的组装数量。现有某月初仓库中的两类物品数量,请计算本月两类汽车的产量。

输入说明:两种部件的合格品数量;

输出说明:两类汽车的生产数量;

输入样例:20  16

输出样例:2   2

public class Main2 {
/**
* 4x+6y=m;
* 3x+5y=n;
*/
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
int m,n,x,y;
m=input.nextInt();
n=input.nextInt();
y=(3*m-4*n)/(3*6-4*5);
x=(n-5*y)/3;
System.out.println(x+" "+y);
input.close();
}
}

3.(10分) 内容检索是计算机的强项,现有一段英文文字和一个英文关键词,请找出这个关键词在这段英文文字中的位置,如果该关键词出现不止一次,请输出该关键词第一次出现的位置。

输入说明:一段英文文字(含有空格和标点符号,以’!’作为结束符)和一个英文关键词;

输出说明:关键词第一次出现的位置,首位置记为1;

输入样例:Today is Oct 9. There are seven cats in the house. They are very happy!

are

输出样例:23

public class Main3 {

    public static void main(String[] args) throws IOException {
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
String str = reader.readLine();
String obj_str = reader.readLine();
System.out.println(str.indexOf(obj_str)+1);
}
}

4.(10分) 统计二维整数数组中,横向或纵向连续3个相邻元素的最大和。

输入说明:数组行数x列数 y, 二维整数数组中元素;

输出说明:此数组中横向或纵向连续3个相邻元素的最大和。

输入样例:4  4

3  6  0  8

1  0  2  4

2  0  1  9

0  1  2  3

输出样例:21

3 6 0 8 2
3 6 0 8 4 3
3 6 0 8 5 6 4
3 6 0 8 5 6 7 5

package P;

import java.util.Scanner;

public class Main4 {

    public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int n, m;
n = in.nextInt();
m = in.nextInt();
int[][] matrix = new int[n][m];
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
matrix[i][j] = in.nextInt();
}
}
int Max = Integer.MIN_VALUE;
for (int i = 0; i < n; i++) {
for (int j = 0; j < m-2; j++) {
int sum=0;
for (int k = j; k < 3+j; k++) {
sum+=matrix[i][k];
}
Max=Math.max(Max, sum);
}
for (int j = 0; j < m-2; j++) {
int sum=0;
for (int k = j; k < 3+j; k++) {
sum+=matrix[k][i];
}
Max=Math.max(Max, sum);
}
}
System.out.println(Max);
in.close();
}
}

5.(15分) 请对给出的一系列英文单词按首字母进行排序,并输出排序后的结果。

输入说明:数字N,表明单词数,接下来是N个英文单词;

输出说明:按字母序的排序结果。

输入样例:6

Apple  banana  Zebra  Tuesday  moon  CAN

输出样例:Apple

banana

CAN

moon

Tuesday

Zebra

public class Main5 {
public static void main(String[] args) throws IOException {
Scanner input = new Scanner(System.in);
TreeSet<String> treeSet = new TreeSet<>(new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
return o1.compareToIgnoreCase(o2);
}
});
int n = input.nextInt();
for (int i = 0; i < n; i++) {
treeSet.add(input.next());
}
treeSet.forEach((v)->{System.out.println(v);});
input.close();
}
}

Java菜题的更多相关文章

  1. 50道经典的JAVA编程题(汇总)

    这是一次不可思议的编程历程.从2013年的最后一天开始做这份题,中间连续好几天的考试,包括java考试(今天考试的JAVA编程题),直到今天完成了.挺有成就感的...废话不多说了,来电实质性的吧. 全 ...

  2. 50道经典的JAVA编程题(46-50)

    50道经典的JAVA编程题(46-50),最后五道题了,这是一个美妙的过程,编程真的能让我忘掉一切投入其中,感觉很棒.今天下午考完微机原理了,大三上学期就这样度过了,这学期算是解放了,可是感觉我还是没 ...

  3. 50道经典的JAVA编程题(41-45)

    50道经典的JAVA编程题(41-45),苦逼的程序猿,晚上睡不着了编程吧~今天坚持做10道题!发现编程能是我快乐...O(∩_∩)O哈哈~能平静我烦乱的心,剩下5道题留到考试完了再做吧!该睡觉了.. ...

  4. 今天考试的JAVA编程题

    今天早上考了java, 题目感觉还不错, 共四道题,有一道定义类的没啥意思就没列出来. 这三道题目还是不错的,特别是第一道,大一上学期学linux的时候,那时还没学C语言呢,准确的来说,还不知道什么是 ...

  5. 50道经典的JAVA编程题(36-40)

    50道经典的JAVA编程题(36-40),今天晚上心情压抑,不爽,继续做题,管它明天考试,我继续我的java,一个周末都在看微机原理看得的很头疼啊~明天该挂科就挂吧,不在乎了~~~ [程序36] Ar ...

  6. 50道经典的JAVA编程题(31-35)

    50道经典的JAVA编程题(31-35),今天考完了java,在前篇博客里面贴出了题了,见:<今天考试的JAVA编程题>.考完了也轻松了,下个星期一还考微机原理呢,啥都不会,估计今天就做到 ...

  7. 50道经典的JAVA编程题(26-30)

    50道经典的JAVA编程题(26-30),这么晚了,早点睡了要,明早8点考java祝我好运吧!!!晚安~ [程序26]Ex26.java(跳过了,好没意思的题啊)题目:请输入星期几的第一个字母来判断一 ...

  8. 50道经典的JAVA编程题(21-25)

    50道经典的JAVA编程题(21-25),明天早上java考试了,还是坚持做题吧...这题比老师的题好多了! [程序21]TestJieCheng.java题目:求1+2!+3!+...+20!的和1 ...

  9. 50道经典的JAVA编程题 (16-20)

    50道经典的JAVA编程题 (16-20),用了快一个下午来做这10道题了,整理博客的时间貌似大于编程的时间啊..哈哈 [程序16]Nine.java 题目:输出9*9口诀. 1.程序分析:分行与列考 ...

随机推荐

  1. 通过 Telegraf + InfluxDB + Grafana 快速搭建监控体系的详细步骤

    第一部分 Telegraf 部署和配置 Telegraf 是实现 数据采集 的工具.Telegraf 具有内存占用小的特点,通过插件系统开发人员可轻松添加支持其他服务的扩展. 在平台监控系统中,可以使 ...

  2. linux安装数据时报错Could not execute auto check for display colors using command /usr/bin/xdpyinfo.

    在redhat6.5上安装Oracle时,最后使用oracle用户执行runInstaller 报错如下,无法连接到安装有xmanager的windows服务器,也就无法图形化安装oracle ora ...

  3. 如何使用终端默认情况下阻止Mac应用保存到iCloud

    当您保存要在Mac上的Pages,Numbers,TextEdit或其他基于云的应用程序中处理的文档时,该保存的默认位置是iCloud.尽管这对某些人或某些文档来说可能是一件好事,但您可能会厌倦每次更 ...

  4. Git入门基础教程

    目录 一.Git的安装 1.1 图形化界面 1.2 命令行界面 二.本地仓库的创建与提交 2.1 图形化界面 2.1.1 首先在电脑上有一个空白目录 2.1.2 打开SourceTree 2.1.3 ...

  5. day97_11_29

    一.数据存储到mongodb 爬取的数据如果需要存储到mongodb中,要通过item,定义一个存储类.再yield一个类. 数据存储的时候需要进过pipelines,再到setting中配置. fr ...

  6. quarter软件的破解

    链接;http://www.openedv.com/forum.php?mod=viewthread&tid=275857&extra=page%3D1 这个是正点原子提供的破解方法, ...

  7. ubuntu vscode 写一个C++程序

    博客转载:https://blog.csdn.net/weixin_43374723/article/details/84064644 Visual studio code是微软发布的一个运行于 Ma ...

  8. Jenkins学习安装配置和使用

    为了能够频繁地将软件的最新版本,及时.持续地交付给测试团队及质量控制团队,以供评审,所以引入持续集成工具Jenkins,从而实现公司新产品持续集成,自动化部署. 环境准备 ●操作系统:Windows1 ...

  9. jvaa之初始化块

    1.初始化块的作用:对java对象进行初始化: 2.程序的执行顺序:声明成员变量的默认值-->显示初始化,多个初始化块依次被执行(同级别下按先后顺序执行)-->构造器在对成员进行赋值操作. ...

  10. .NET Core 实现 腾讯云云解析简单客户端

    一.说明 腾讯云的.NET SDK虽然非常强大,但是对他的产品支持不是很完全,域名的云解析就没有SDK,所以自己写了一个,初衷是用来做动态DNS的,也准备接入多个云厂商,但是我自己本身仅仅只有腾讯云这 ...