java算法题

本文共 3,425 字,预计阅读时间 11 分钟

 


1.下面输出结果是什么?

复制代码
public class Test {
    public static void main(String[] args) {
        Person person=new Person("张三");
        change(person);
        System.out.println(person.name);
    }
    public static void change(Person person) {
        Person person2=new Person("李四");
        person=person2;
    }
}
public class Person {
    String name;
    public Person(String name) {
        this.name = name;
    }
}
复制代码

答案:张三。原因是change的方法又创建了一个对象,是不同的对象,所以不能改变name的值。

2.下面输出结果是什么?

复制代码
public class Test2 {
    public static void main(String[] args) {
        Thread thread=new Thread() {
            public void run() {
                pong();
            }
        };
        thread.run();
        System.out.print("ping");
    }
    public static void pong() {
        System.out.print("pong");
    }
}
复制代码

答案:pongping。线程会先执行。

3.以下代码有哪些错误?

复制代码
public static int getIndexOfArray(float[] f) {
        int rtn=-1;
        float objf=3.4;
        List list=null;
        for (int i = 0; i < f.size(); i++) {
            list.add(f[i]);
        }
        for (int i = 0; i < list.size(); i++) {
            float temp=(float) list.get(i);
            if(objf==temp) {
                rtn=i;
            }
        }
        return rtn;
    }
复制代码

答案:1)3.4改为3.4f,这里需要进行强转;

      2)f.size()改为f.length,数组的长度用length属性;

   3)list=null 要改为new ArrayList<>();不然list.add会报空指针异常。

4.list集合与string的相互转换

复制代码
 List list=new ArrayList<Integer>();
         list.add(1);
         list.add(2);
         list.add(3);
         //list转string字符串
         StringBuilder string=new StringBuilder();
         for(int i=0;i<list.size();i++) {
             string.append(list.get(i));
             if(i<list.size()-1) {
                 string.append(",");
             }
         }
         System.out.println(new String(string));
复制代码
1
2
//string转list
List moduleList= Arrays.asList(modules.split(","));

5.按下面的图案打印10行

分析:图案每一行的第一个和最后一个元素都是1,然后从第二行开始,每行的元素是他上一行对应的列与此列前面的那个数之和。

复制代码
 public static void sanjiaoxing(){
        int i, j;
        int N=11;
        int a[][]=new int[N][N];
        for (i = 0; i < N; i++) {
            a[i][i] = 1;
            a[i][0] = 1;
        }
        for (i = 2; i < N; i++) {
            for (j = 1; j <= i - 1; j++) {
                a[i][j] = a[i - 1][j - 1] + a[i - 1][j];
            }
        }
        for (i = 0; i < N; i++) {
            for (j = 0; j < i; j++) {
                System.out.print(" " + a[i][j]);
            }
            if(i!=0)System.out.println();
        }
    }
复制代码

6.分桃子吃

海滩上有一堆桃子,五只猴子来分。第一只猴子把这堆桃子凭据分为五份,多了一个,这只猴子把多的一个扔入海中,拿走了一份。第二只猴子

把剩下的桃子又平均分成五份,又多了一个,它同样把多的一个扔入海中,拿走了一份,第三、第四、第五只猴子都是这样做的,问海滩上原来最少有多少个桃子? 
复制代码
public class Test {

    static final int num=5;//猴子数量

    public static void main(String args[]) {
        int total=6;//最后至少有6个
        while (true){
            if(isDivision(total)){
                break;
            }
            total++;
        }
        System.out.println(total);
    }

    public static boolean isDivision(int n){
        int i=0;
        while(i<num&&n>0){
            if((n-1)%5==0){
                int temp=(n-1)/5+1;
                n-=temp;
                i++;
            }else{
                return false;
            }
        }
        return true;
    }
}
复制代码

7.

 

posted @   钟小嘿  阅读(279)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示