当前位置: 首页 > news >正文

Java基础:笔试题

在这里插入图片描述

文章目录

  • Java 基础
    • 题目
      • 1. 如下代码输出什么?
      • 2. 当输入为2的时候返回值是多少?
      • 3. 如下代码输出值为多少?
      • 4. 给出一个排序好的数组:{1,2,2,3,4,5,6,7,8,9} 和一个数,求数组中连续元素的和等于所给数的子数组
    • 解析
      • 第一题
      • 第二题
      • 第三题
      • 第四题
        • 方案一:给定数为:10
        • 方案二:即给定数字限定为:7

Java 基础

题目

1. 如下代码输出什么?

public classTest {
public void change(String str,char[] ch) {
	str= "test ok";
	ch[0] = 'g';
}

public static voidmain(String[] args) {
	String str= new String("good");char[] ch = {'a','b','c'};
	Test te= newTest();
	te.change(str,ch);
	System.out.print(str+ "and");
	System.out.print(ch);

	}
}

2. 当输入为2的时候返回值是多少?

public static int getValue(int i) {
	int result = 0;
	switch (i) {
		case 1:
		result = result + i;
		case 2:
		result = result + i * 2;
		case 3:
		result = result + i * 3;
	}
	return result;
}

3. 如下代码输出值为多少?


public class Base
{
    private String baseName = "base";
    
    public Base(){
        callName();
    }

    public void callName() {
        System. out. println(baseName);
    }

    static class Sub extends Base{
    
        private String baseName = "sub";
        public void callName(){
            System.out.println(baseName) ;
        }
    }
    public static void main(String[] args){
        Base b = new Sub();
    }
}

4. 给出一个排序好的数组:{1,2,2,3,4,5,6,7,8,9} 和一个数,求数组中连续元素的和等于所给数的子数组

解析

第一题

  • 答案:goodandgbc
  • 这个题目很简单其主要细节在于输出语句: print,看清楚他是不换行的

第二题

  • 答案:10
  • 细节:没有 break ,所以他会继续执行下面的条件

第三题

  • 答案:null
  • 这一道题来自携程的笔试题,点击此处:答案解析

第四题

方案一:给定数为:10

  • 使用两层循环必定可以解决这个问题,但是因为是两个数据求和,在集合有序的情况下使用一次循环就可以解决这个问题。
  • 思路如下:因为数组有序这,可以让数组从两头开始向加
 public static void main(String[] args) {
 
        int[] num = {1,2,2,3,4,5,6,7,8,9};
        int sum = 10;
        int i = 0;
        int j = num.length - 1;
 
        while (i < j){
            if( num[i] + num[j] > sum){
                j --;
            }
            if( num[i] + num[j] < sum){
                i ++;
            }
            if( num[i] + num[j] == sum){
                System.out.println(num[i]  + "---" + num[j]);
            }
            i ++;
         
        }
    }

方案二:即给定数字限定为:7

 public static void main(String[] args){
        int[] num = {1,2,2,3,4,5,6,7,8,9};
        int sum = 7;
        findSum(num,sum);
    }

    private static void findSum(int[] num,int sum){
        int left=0;
        int right=0;

        for(int i=0;i<num.length;i++){
            int curSum = 0;
            left = i;
            right = i;
            while(curSum<sum){
                curSum += num[right++];
            }
            if(curSum==sum){
                for(int j=left;j<right;j++){
                    System.out.print(num[j]+" ");
                }
                System.out.println();
            }
        }
	}	

相关文章:

  • Java基础:笔试题
  • Linux 信号(signal):信号的生命周期
  • 归并排序和快速排序
  • 【C语言】你真的了解结构体吗
  • 精心整理前端主流框架学习路径
  • 深度剖析自定义类型(结构体、枚举、联合)——“C”
  • PCL 使用ICP点云拼接
  • 【SQL开发实战技巧】系列(二十七):数仓报表场景☞通过对移动范围进行聚集来详解分析函数开窗原理以及如何一个SQL打印九九乘法表
  • 【JS】常用js方法
  • 用C跑爬虫
  • Qt调用Chrome浏览器
  • 2023年网络安全趋势
  • 冒泡 VS 插入 VS 选择——谁更胜一筹?(附排序源码)
  • Java怎么实现几十万条数据插入(30万条数据插入MySQL仅需13秒)
  • 【C++进阶】哈希表详解
  • 【绘图】比Matplotlib更强大:ProPlot
  • 【CMake实例篇】07.编译参数传递宏定义
  • proxy详细介绍与使用
  • 企业全球化出海技术体系建设实录【专题合集】
  • 176万,GPT-4发布了,如何查看OpenAI的下载量?