1、回文

分析

暴力枚举一下check回文,可以确定出最后答案的一半,就可以得到答案了。

参考代码

#include

using namespace std;

bool isPalindrome(string s) {

int i = 0, j = s.size() - 1;

while(i < j)

if(s[i++] != s[j--])

return false;

return true;

}

string s;

int main() {

cin >> s;

string add;

int i, j;

for(i = 0; i < s.size(); i++) {

if(isPalindrome(s.substr(i))) break;

}

for(int j = i - 1; j >= 0; j--) add += s[j];

s += add;

cout << s.size() << endl;

}

2、两个子串

分析

暴力枚举计算字符串前缀后缀相等的最长长度,然后拼接一下就是结果。

参考代码

#include

using namespace std;

string s;

int main() {

cin >> s;

int l = s.size(), m = 0;

for(int i = 1; i < l; i++) {

if(s.substr(0, i) == s.substr(l - i, i))

m = i;

}

cout << s.substr(0, l - m) + s << endl;

return 0;

}

3、括号匹配方案

分析

这个题字符串长度不长,可以直接爆搜。

有一种代码比较简单的解法,挨着累计'('的个数,遇到')'就完成一次匹配,把情况数乘进答案。本质是把题目所说的移除操作做了一个等价的变化。

参考代码

#include

using namespace std;

string s;

int main() {

cin >> s;

int ans = 1, cnt = 0;

for(int i = 0; i < s.size(); i++) {

if(s[i] == '(') {

cnt++;

} else {

ans *= cnt;

cnt--;

}

}

cout << ans << endl;

}

4、疯狂的序列

分析

范围比较大,考虑二分答案,等差数列求和来check。

参考代码

#include

using namespace std;

long long n;

int main() {

cin >> n;

long long l = 1, r = 2000000000LL, mid;

while(l < r) {

mid = (l + r) / 2;

if(mid * (mid + 1) / 2 >= n)

r = mid;

else

l = mid + 1;

}

cout << l << endl;

return 0;

}

5、神奇数

分析

注意到r - l不会特别大,直接枚举范围内的数,然后暴力check。

暴力check的时候注意到所有数位和最大只有81,所以会比较快。

参考代码一

#include

using namespace std;

bool check(int n) {

char s[11];

int cur = 0, t = 0;

while(n > 0) {

s[cur] = n % 10;

t += s[cur++];

n /= 10;

}

if(t % 2) return false;

t /= 2;

bool ok[42] = {0};

ok[s[0]] = true;

for(int i = 1; i < cur; i++) {

int v = s[i];

for(int j = 41; j >= 0; j--) {

if(ok[j] && j + v <= 41) {

ok[j + v] = true;

}

}

if(ok[t]) {

return true;

}

}

return false;

}

int l, r;

int main() {

int res = 0;

cin >> l >> r;

for(int i = l; i <= r; i++) {

if(check(i)) res++;

}

cout << res << endl;

return 0;

}

参考代码二

import java.util.HashSet;

import java.util.Scanner;

import java.util.Set;

public class Main {

public static boolean check(int n){

int[] s = new int[11];

int cur = 0, t = 0;

while(n > 0) {

s[cur] = n % 10;

t += s[cur++];

n /= 10;

}

if( t % 2 == 1 ) return false;

t /= 2;

boolean[] ok = new boolean[42];

ok[s[0]] = true;

for(int i = 1; i < cur; i++) {

int v = s[i];

for(int j = 41; j >= 0; j--) {

if(ok[j] && j + v <= 41) {

ok[j + v] = true;

}

}

if(ok[t]) {

return true;

}

}

return false;

}

public static int max(int a, int b){

return (a>b) ? a : b;

}

public static void main(String[] args) {

Scanner in = new Scanner(System.in);

int res = 0;

int l = in.nextInt();

int r = in.nextInt();

for(int i = l; i <= r; i++) {

if(check(i)) res++;

}

System.out.println(res);

}

}

6、求幂

分析

裸暴力好像只能拿20%的分

我们考虑去枚举n范围内的所有i,然后处理出i的幂那些数。

考虑对于i ^ x, 我们需要计算满足 (i ^ x) ^ c = (i ^ y) ^ d的数量,其中i ^ x, i ^ y <= n. 这些我们可以通过预处理出来。

然后对于(i ^ x) ^ c = (i ^ y) ^ d 其实意味着x c = y d, 意味着(x / y) = (d / c), 其中x, y我们可以在预处理之后枚举出来,于是我们就可以借此计算出n范围内有多少不同这种c和d去满足等式。

其实就等于 n / max(x / gcd(x, y), y / gcd(x, y)),然后都累加进答案。gcd()表示最大公约数。

中间可能产生重复枚举,我们用一个set或者hash容器标记一下就好。

以上枚举对于2~sqrt(n)。最后对于大于sqrt(n)的部分,每个的贡献都是n。

参考代码一

#include

using namespace std;

const int mod = 1e9 + 7;

set S;

int n;

int main() {

cin >> n;

long long res = 1LL * n * n % mod;

for(int i = 2; i * i <= n; i++) {

if(S.find(i) != S.end()) continue;

long long tmp = i;

int cnt = 0;

while(tmp <= n) {

S.insert(tmp);

tmp = tmp * i;

cnt++;

}

for(int x = 1; x <= cnt; x++) {

for(int y = 1; y <= cnt; y++) {

int g = __gcd(x, y);

int tmpx = x / g;

int tmpy = y / g;

res = (res + n / max(tmpx, tmpy)) % mod;

}

}

}

res += 1LL * (n - S.size() - 1) * n;

res %= mod;

cout << res << endl;

}

参考代码二

import java.util.HashSet;

import java.util.Scanner;

import java.util.Set;

public class Main {

public final static long MOD = 1000000000 + 7;

public static int max(int a, int b){

return (a>b) ? a : b;

}

public static long gcd(long a,long b){

return (a % b == 0) ? b : gcd(b,a%b);

}

public static void main(String[] args) {

Scanner in = new Scanner(System.in);

long n = in.nextInt();

long ans = (long)1*n*(n*2-1) % MOD;

Set set = new HashSet<>();

for (int i = 2; i*i <= n; i++){

if ( set.contains(i)) continue;

long tmp = i;

int cnt = 0;

while(tmp <= n) {

set.add((int)tmp);

tmp = tmp * i;

cnt++;

}

for(int k = 1; k <= cnt; k++) {

for(int j = k + 1; j <= cnt; j++) {

ans = (ans + n / (j / gcd(k, j) ) * (long)2 ) % MOD;

}

}

}

System.out.println(ans);

}

}

7、购物车

function add(items) {

var tbody = document.getElementById('jsTrolley').getElementsByTagName('tbody')[0];

(items || []).forEach(function (item) {

var tr = document.createElement('tr');

tr.innerHTML = '

' + item.name

+ '

' + item.price.toFixed(2) + '删除';

tbody.appendChild(tr);

});

update();

}

function bind() {

var table = document.getElementById('jsTrolley');

table.addEventListener('click', function (event) {

var el = event.target;

if (el.tagName.toLowerCase() === 'a') {

tr = el.parentNode.parentNode;

tr.parentNode.removeChild(tr);

update();

}

});

}

function update() {

var table = document.getElementById('jsTrolley');

var tbody = table.getElementsByTagName('tbody')[0];

var tfoot = table.getElementsByTagName('tfoot')[0];

var tr = [].slice.call(tbody.getElementsByTagName('tr'), 0);

var total = 0;

tr.forEach(function (tr) {

total += +(tr.getElementsByTagName('td')[1].innerHTML.trim());

});

tfoot.getElementsByTagName('td')[0].innerHTML = total.toFixed(2) + '(' + tr.length + '件商品)';

}

欢迎关注 “BAT笔试面试” 微信公众号

全栈面试题,你想要的都在这^_^

京东校招java笔试题_京东2018校招技术笔试编程题汇总相关推荐

  1. 京东校招java面试题_京东2018校招编程题解答(Java)

    写在前面 本文主要是解答这次校招中京东的笔试编程题,这次京东的笔试编程题比较难,涉及KMP算法.manacher算法等.文中的解法也是在观看了左神(左程云)9月20号在牛客网的直播后,自己花时间写出来 ...

  2. 用友2020校招java笔试题_用友Java类笔试题大全

    如下为大家汇总的是一份用友Java类笔试题,欢迎大家关注! 1.Hashtable和HashMap有什么区别? a.Hashtable是继承自陈旧的Dictionary类的,HashMap继承自Abs ...

  3. 京东校招java笔试题_试卷: 京东2019校招笔试Java开发工程师笔试题(1-)

    D 把资源事先分类编号,按号分配,使进程在申请,占用资源时不会形成环路. 解析:死锁:在多道程序设计环境下,多个进程可能竞争一定数量的资源,.一个进程申请资源,如果资源不可用,那么进程进入等待状态.如 ...

  4. 京东校招java笔试题_2017京东校招笔试编程题:进制转换、辗转相除

    题目描述 时间限制:C/C++语言 1000MS 其他语言:3000MS 内存限制:C/C++语言 65536KB 其他语言:589824KB 题目内容:尽管是一个CS专业的学生,小B的数学基础很好并 ...

  5. 网易校招java笔试题_网易笔试题详细解答(Java)

    对于下面公式不显示的问题,可以看这个链接 显示效果更好. 题目一 题目描述 小易觉得高数课太无聊了,决定睡觉.不过他对课上的一些内容挺感兴趣,所以希望老师讲到有趣的地方的时候叫醒他一下.你知道了小易对 ...

  6. 埃森哲java笔试题_埃森哲的笔试经验

    埃森哲的笔试经验 今天起了一个大早,确实是大早,天还没有怎么亮!目的只有一个就是去参加埃森哲的笔试,地点在北航! 这是一个寒冷的大早,昨天晚上实验室的一个同学还说今天估计是个好天气,可惜天不从人愿,今 ...

  7. 用友2020校招java笔试题_2020年快手校招JAVA岗笔试第三题-Go语言中文社区

    题目描述: 将两个内容合并,每次,取第一行四个,取第二行5个.把多余的直接补在最后即可. 解题代码 import java.util.Scanner; public class Main_3 { pu ...

  8. 华为校招java笔试题库_华为校招Java笔试题库,看你会不会做

    1.在java中如果声明一个类为final,表示什么意思? 答:final是最终的意思,final可用于定义变量.方法和类但含义不同,声明为final的类不能被继承. 2.父类的构造方法是否可以被子类 ...

  9. java笔试题_公司真题 | 用友2018秋招Java笔试题(四)

    公司真题 | 用友2018秋招Java笔试题(三)答案: 1.正确答案 A B 2.正确答案 A 3.正确答案 D 4.正确答案 B 5.正确答案 A E 6.正确答案 B 7.正确答案 C D 8. ...

最新文章

  1. ubuntu操作系统下载
  2. FauxPas试用时间破解
  3. 恒位油杯故障原因_厂家详解干式真空泵故障分析与保养办法
  4. ASP中随机函数Randomize的使用
  5. 深入理解BeanPostProcessor接口
  6. 颜色模型和颜色应用---小结
  7. 数据结构 快速排序的三种实现 (hoare版本 挖坑法 前后指针版本)与非递归实现
  8. 【matlab-1】工具箱、窗口、变量的存储与加载、帮助
  9. 31篇文章!计算机视觉从原理到OpenCv实战
  10. 为什么人和人的差距这么大?
  11. 诱人的 react 视频教程-基础篇(14 个视频)
  12. MAC上编写汇编程序
  13. 如何用html把图片做成动画的软件,如何用HTML做动画?
  14. 手把手教你使用R语言做出一篇20分SCI文章的交互效应表(p for Interaction)
  15. Java jdt 编辑_JDT:打开Java编辑器并显示特定成员
  16. EI会议论文被检索难度评定
  17. 西门子PPI协议的工控通信控件
  18. js算法之旅:用队列和栈计算出扑克玩:拖板车(小猫钓鱼) 游戏的结果
  19. 关于个人工作总结的一点浅见
  20. 如何判断序列是不是堆_如何判断自己是不是精神分裂

热门文章

  1. 美国陆军拟用机器人取代普通士兵
  2. DA 蜻蜓优化算法 - 逐句拆解 - 含代码
  3. Swift 中的关键字详解
  4. Android内部h5和native交互实现方式
  5. 万年历定时关机c语言代码,C语言程序设计能力教程电子万年历设计.doc
  6. 微信HTML5小游戏之困住神经猫
  7. 计算机与书法专业,厉害了!计算机应用专业的他获省级书法比赛一等奖
  8. DELL PowerEdge R620 U盘启动
  9. java-php-python-ssm校园跑腿平台演示录像2020计算机毕业设计
  10. Linux驱动之模拟PWM驱动