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));
//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.

java算法题的更多相关文章

  1. 一道java算法题分析

    最近在面试中遇到这样的一道算法题:       求100!的结果的各位数之和为多少?       如:5!=5*4*3*2*1=120,那么他们的和为1+2+0=3这道题不算难,不过倒是注意的细节也有 ...

  2. 面试-java算法题

    1.编写一个程序,输入n,求n!(用递归的方式实现). public static long fac(int n){ if(n<=0) return 0; else if(n==1) retur ...

  3. 【JAVA算法题】职业抢劫

    题目 /*You are a professional robber planning to rob houses along a street. * Each house has a certain ...

  4. 25道经典Java算法题

    题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?   //这是一个菲波拉契数列问题 [Java] 纯 ...

  5. 50道java算法题(一)

    [程序1] 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? 1.程序分析:   兔子的规律为数列1 ...

  6. 趣味Java算法题(附答案)

    [程序1]    题目:古典问题:有一对兔子,从出生后第3个月起每一个月都生一对兔子,小兔子长到第三个月后每一个月又生一对兔子,假如兔子都不死,问每一个月的兔子总数为多少?    //这是一个菲波拉契 ...

  7. 某厂java算法题实现及改进【有n个人成一圈,顺序排号(编号为1到n),从第一个人开始报数1到3报数】

    一.第一种实现: 实现比较简单,直接贴现成的代码了,第一种实现: /** * 总人数 * * @param d */ private static void sortQuerry1(int d) { ...

  8. 面试题-JAVA算法题

    1.编写一个程序,输入n,求n!(用递归的方式实现). public static long fac(int n){ if(n<=0) return 0; else if(n==1) retur ...

  9. java算法题每日一练01,java入门简单算法题小练

    1.给数组做反序 public class Ak01 { public static void main(String[] args) { int[] a = new int[]{22,48,41,2 ...

  10. Java算法题:求素数

    题目:判断101-200之间有多少个素数,并输出所有素数. 思路:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,则表明此数不是素数,反之是素数. 具体代码: public Ve ...

随机推荐

  1. (7)Linux使用注意事项

    1.Linux 严格区分大小写 和 Windows 不同,Linux 是严格区分大小写的,包括文件名和目录名.命令.命令选项.配置文件设置选项等. 2.Windows 下的程序不能直接在 Linux ...

  2. dedecms文章页的上下篇颠倒的问题

    dedecms的文章页底下的上下篇,如果按照时间排序的话,最新的一篇应该是最上了,但是底下还是会显示上一篇文章还有,然后下一篇文章没有了,就是颠倒了.如何修改呢. 1.修改include目录下arc. ...

  3. Jenkins(6)测试报告邮件发送

    前言 前面已经实现在jenkins上展示html的测试报告,接下来只差最后一步,把报告发给你的领导,展示你的劳动成果了. 安装 Email Extension Plugin 插件 jenkins首页- ...

  4. 2019牛客暑期多校训练营(第五场)H-subsequence 2 (拓扑排序+思维)

    >传送门< 题意: 给你几组样例,给你两个字符a,b,一个长度len,一个长度为len的字符串str,str是字符串s的子串 str是s删掉除过a,b两字符剩下的子串,现在求s,多种情况输 ...

  5. 牛客练习赛64 D【容斥+背包】

    牛客练习赛64 D.宝石装箱 Description \(n\)颗宝石装进\(n\)个箱子使得每个箱子中都有一颗宝石.第\(i\)颗宝石不能装入第\(a_i\)个箱子.求合法的装箱方案对\(99824 ...

  6. 【uva 247】Calling Circles(图论--Floyd 传递闭包+并查集 连通分量)

    题意:有N个人互相打了M次电话,请找出所有电话圈(Eg.a→b,b→c,c→d,d→a 就算一个电话圈)并输出.(N≤25,L≤25,注意输出格式) 解法:由于N比较小所有n^2或n^3的复杂度都没有 ...

  7. 二、Python基础(input、变量名、条件语句、循环语句、注释)

    一.input用法 input在Python中的含义为永远等待,直到用户输入了值,从而将所输入的值赋值另外的一个东西. n=input('请输入......') 接下来用一个例子学习input的用法 ...

  8. Jmeter入门使用

    1. 什么是Jmeter 转自:https://www.cnblogs.com/lijuanhu321/p/9537185.html#testComponent https://www.cnblogs ...

  9. 说说Golang goroutine并发那些事儿

    摘要:今天我们一起盘点一下Golang并发那些事儿. Golang.Golang.Golang 真的够浪,今天我们一起盘点一下Golang并发那些事儿,准确来说是goroutine,关于多线程并发,咱 ...

  10. CF1465-D. Grime Zoo

    CF1465-D. Grime Zoo 题意: 一个长度为n,由\(0,1,?\)这三个字符构成的字符串,字符串中\(01\)子串贡献\(x\)值,\(10\)的子串贡献\(y\)值,现在让你把\(? ...