Java基础:笔试题

在这里插入图片描述

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 ,所以他会继续执行下面的条件

第三题

第四题

方案一:给定数为: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();
            }
        }
	}	

猜你喜欢

转载自blog.csdn.net/Mango_Bin/article/details/129627219