java算法题
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算法题的更多相关文章
- 一道java算法题分析
最近在面试中遇到这样的一道算法题: 求100!的结果的各位数之和为多少? 如:5!=5*4*3*2*1=120,那么他们的和为1+2+0=3这道题不算难,不过倒是注意的细节也有 ...
- 面试-java算法题
1.编写一个程序,输入n,求n!(用递归的方式实现). public static long fac(int n){ if(n<=0) return 0; else if(n==1) retur ...
- 【JAVA算法题】职业抢劫
题目 /*You are a professional robber planning to rob houses along a street. * Each house has a certain ...
- 25道经典Java算法题
题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? //这是一个菲波拉契数列问题 [Java] 纯 ...
- 50道java算法题(一)
[程序1] 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? 1.程序分析: 兔子的规律为数列1 ...
- 趣味Java算法题(附答案)
[程序1] 题目:古典问题:有一对兔子,从出生后第3个月起每一个月都生一对兔子,小兔子长到第三个月后每一个月又生一对兔子,假如兔子都不死,问每一个月的兔子总数为多少? //这是一个菲波拉契 ...
- 某厂java算法题实现及改进【有n个人成一圈,顺序排号(编号为1到n),从第一个人开始报数1到3报数】
一.第一种实现: 实现比较简单,直接贴现成的代码了,第一种实现: /** * 总人数 * * @param d */ private static void sortQuerry1(int d) { ...
- 面试题-JAVA算法题
1.编写一个程序,输入n,求n!(用递归的方式实现). public static long fac(int n){ if(n<=0) return 0; else if(n==1) retur ...
- java算法题每日一练01,java入门简单算法题小练
1.给数组做反序 public class Ak01 { public static void main(String[] args) { int[] a = new int[]{22,48,41,2 ...
- Java算法题:求素数
题目:判断101-200之间有多少个素数,并输出所有素数. 思路:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,则表明此数不是素数,反之是素数. 具体代码: public Ve ...
随机推荐
- [SpringSecurity] UserDetailsService 详解
UserDetailsService 接口 当什么也没有配置的时候,账号和密码是由 Spring Security 定义生成的. 而在实际项目中账号和密码都是从数据库中查询出来的. 所以我们要通过自定 ...
- linux(9)find命令详解
find命令格式: find path -option [ -print ] [ -exec -ok command ] {} \; find命令的参数: path:要查找的目录路径. ~ 表示$HO ...
- NetCore控制台程序-使用HostService和HttpClient实现简单的定时爬虫
.NetCore承载系统 .NetCore的承载系统, 可以将长时间运行的服务承载于托管进程中, AspNetCore应用其实就是一个长时间运行的服务, 启动AspNetCore应用后, 它就会监听网 ...
- Codeforces Round #626 (Div. 2) D. Present(位运算)
题意: 求n个数中两两和的异或. 思路: 逐位考虑,第k位只需考虑0~k-1位,可通过&(2k+1-1)得到一组新数. 将新数排序,当两数和在[2k,2k+1)和[2k+1+2k,2k+2)之 ...
- Codeforces Round #604 (Div. 2) A. Beautiful String(贪心)
题目链接:https://codeforces.com/contest/1265/problem/A 题意 给出一个由 a, b, c, ? 组成的字符串,将 ? 替换为 a, b, c 中的一个字母 ...
- Codeforces Round #650 (Div. 3) B. Even Array
题目链接:https://codeforces.com/contest/1367/problem/B 题意 有一大小为 $n$ 的数组 $a$,问能否经过交换使所有元素与下标奇偶性相同(0 - ind ...
- Codeforces Round #660 (Div. 2) Captain Flint and Treasure 拓扑排序(按照出度、入读两边拓扑排序)
题目链接:Captain Flint and Treasure 题意: 一种操作为 选一个下标 使得ans+=a[i] 且 把a[b[i]]+a[i] 要求每个下标都进行一种这样的操作,问怎么样的 ...
- hdu2546 饭卡
Problem Description 电子科大本部食堂的饭卡有一种很诡异的设计,即在购买之前判断余额.如果购买一个商品之前,卡上的剩余金额大于或等于5元,就一定可以购买成功(即使购买后卡上余额为负) ...
- MySql 执行 DELETE/UPDATE时,报 Error Code: 1175错误
MySql 执行 DELETE FROM Table 时,报 Error Code: 1175. You are using safe update mode and you tried to upd ...
- 洛谷 P1629 邮递员送信-反向建边
洛谷 P1629 邮递员送信 题目描述: 有一个邮递员要送东西,邮局在节点 11.他总共要送 n-1n−1 样东西,其目的地分别是节点 22 到节点 nn.由于这个城市的交通比较繁忙,因此所有的道路都 ...