关注
import
java.util.ArrayList;
import java.util.HashMap;
import java.util.Scanner;
publicclass Main {
public
static
void main(String[] args) {
Solution s =
new Solution();
s.doBefore();
Scanner sc =
new
Scanner(System.in);
int
t = sc.nextInt();
for(int
i = 0; i < t; i++) {
int
n = sc.nextInt();
s.getResult(n);
}
sc.close();
}
}
class Solution {
public
ArrayList<int[]>
curResult = new ArrayList<int[]>();
publicboolean
mark
= false;
public
void doBefore() {
int
last = 0;
for(int
i = 1; i <= 100000; i++) {
if(f(i) == g(i)) {
int[]
arr = {i, ++last};
curResult.add(arr);
}
}
}
public
void getResult(int
n) {
int
result = 1;
for(int
i = 0; i < curResult.size(); i++) {
if(curResult.get(i)[0] <= n) {
result
= curResult.get(i)[1];
} else
break;
}
System.out.println(result);
}
// int curMostClosed = 1;
// int result = 1; //当前结果是0;
//
// if (mark) {
// for (int k :
curResult.keySet()) {
// if (k >
curMostClosed && k <= n) {
// curMostClosed
= k;
// }
// }
// result =
curResult.get(curMostClosed);
// }
// mark = true;
//
// for(int i = curMostClosed
+ 1; i <= n; i++) {
// if(f(i) == g(i))
// result++;
// }
// curResult.put(n, result);
//
//
System.out.println(result);
// }
privateint f(int
n
) {
int
result = 0;
while(n != 0) {
result +=
n % 10;
n /= 10;
}
return
result;
}
privateint g(int
n
) {
int
result = 0;
while(n != 0) {
result +=
(n & 1) == 1 ? 1 :
0;
n
>>>= 1;
}
return
result;
}
}
这是幸运数那道题,打注释的是我一开始写的方法,后来发现本地运行是可以的,但是OJ说是运行时错误,于是开始使劲想,发现其实输入大小不是很大,于是直接预处理搞了100000个数。结果这样就AC了
查看原帖
点赞 1
相关推荐
点赞 评论 收藏
分享
查看6道真题和解析 点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 实习生的蛐蛐区 #
980857次浏览 4917人参与
# 你上一次给父母打电话是什么时候 #
45043次浏览 278人参与
# 27届实习投递记录 #
152508次浏览 1586人参与
# 父母对你找工作是助力还是阻力? #
49400次浏览 420人参与
# 万物皆可发面经 #
832次浏览 18人参与
# 找工作时的取与舍 #
139149次浏览 927人参与
# 多益网络工作体验 #
74200次浏览 316人参与
# 实习,不懂就问 #
222296次浏览 1726人参与
# 多益网络求职进展汇总 #
109073次浏览 409人参与
# 一起聊华为 #
221749次浏览 973人参与
# 从mentor身上学到了__ #
65880次浏览 907人参与
# 求职中的尴尬瞬间 #
42489次浏览 127人参与
# 薪资一样,你会选择去大厂还是小公司 #
35734次浏览 133人参与
# 实习的内耗时刻 #
243000次浏览 1670人参与
# 发工资后,你做的第一件事是什么 #
107864次浏览 348人参与
# 我和mentor的爱恨情仇 #
119746次浏览 1004人参与
# 你觉得mentor喜欢什么样的实习生 #
62220次浏览 1045人参与
# 牛友投递互助,不漏校招机会 #
495727次浏览 5371人参与
# 你的mentor是什么样的人? #
64886次浏览 804人参与
# 新凯来求职进展汇总 #
83031次浏览 195人参与
