2017 携程 笔试编程题 1

简介: 前言正文题目要求思路n10n 18核心测试总结前言今天参加了携程的笔试,编程题第一题一开始想错了方向,花费了很多时间(虽然第二题就是给时间也不一定做得出来,(⊙﹏⊙)b)。

前言

今天参加了携程的笔试,编程题第一题一开始想错了方向,花费了很多时间(虽然第二题就是给时间也不一定做得出来,(⊙﹏⊙)b)。

下面记录一下这个小插曲。

正文

题目要求

将指定的正整数n分解成若干个互不相同的自然数的和,且使这些自然数的乘积最大

人家给了个输入输出的例子,如下:

输入15
输出 144

言下之意就是在自然数之和为15的这些数字中,乘积最大的一对是

2 3 4 6

思路

为了使得这些自然数之和的乘积最大,那么这些数字应该尽可能的接近。

下面举几个小例子:

n=10

2+3+4 = 9
// 剩下的那个1补到4上面
2+3+5 

这个时候最大的乘积变成了30

n = 18

2+3+4+5 = 14
//按照刚才的思路, 剩下的4 添加到5上面
2+3+4+9

此时最大的乘积结果为216

那么这时的结果是最大的吗?

答案是否定的,因为刚才是从下标为2开始的。如果下标从3,从4开始呢,我们来看下效果。

3+4+5+6 -->> 最大结果为:360
4+5+6+7>18则进行去尾加和
4+5+9  -->> 最大结果为: 180

剩下的其实就不用考虑了。

核心

经过刚才的铺垫,这下不难理解了。最笨的方法就是不断的递增下标,然后记录每一个下标对应的最大值。存储起来,然后找到这些最大值中最大的那个,就是我们要求的结果了。

代码如下:

def mutl(ls):
    result = 1
    for item in ls:
        result *= item
    return result

def compute(n, step):
    path = []
    cursum = 0
    for index in range(step, n):
        if cursum > n:
            last = path.pop()
            path.append(path.pop() + n - (cursum - last))
            break
        path.append(index)
        cursum += index
    return mutl(path)

def my(n):
    total = []
    maxvalue = 0
    for step in range(int(n/2)):
        item = compute(n, step)
        total.append(item)
    maxvalue = max(total)
    return maxvalue



n = 15
result= my(n)
print(result)

运行结果:

144

测试

再来多测几组数据。

  • n=10
30
  • n=18
360

这下,可以啦。需要注意的是:

递增下标到n的一半的位置就可以了,否则结果会不正确,这是因为计算每次的step的时候会把第一个给算进去,所以导致结果偏大。

总结

就携程的笔试题而言,前面部分的问答题和选择题还算是中规中矩,比较偏重于理论和实践。

编程题就真的是考验算法的了。大部分的笔试题都是动态规划类型的。我本人比较偏重于开发方向,所以参加这种笔试题真的是有点力不从心。

不管怎么说,算法是很有必要的。多学点,肯定没错,说不一定以后就用得到了。

我, 还有很长的路要走啊。

目录
相关文章
|
7月前
|
存储 编解码 网络协议
一文搞懂:专升本招生考试应试宝典之计算机基础知识(下)
一文搞懂:专升本招生考试应试宝典之计算机基础知识(下)
|
监控 算法 测试技术
携程2023算法开发岗 一面 二面 面经
携程2023算法开发岗 一面 二面 面经
100 0
|
Cloud Native 算法 程序员
实用的面试经验分享:程序员们谈论他们的面试历程
实用的面试经验分享:程序员们谈论他们的面试历程
86 0
|
消息中间件 NoSQL Java
2023年秋招,金九银十Java后端最全面试攻略,吃透25个技术栈
前言 我分享的这份春招,金三银四Java后端开发面试总结包含了JavaOOP、Java集合容器、Java异常、并发编程、Java反射、Java序列化、JVM、Redis、Spring MVC、MyBatis、MySQL数据库、消息中间件MQ、Dubbo、Linux、ZooKeeper、 分布式&数据结构与算法等25个专题技术点,都是小编在各个大厂总结出来的面试真题,已经有很多粉丝靠这份PDF拿下众多大厂的offer,今天在这里总结分享给到大家!
|
设计模式 算法 中间件
劲爆!阿里巴巴面试参考指南(嵩山版)开源分享,程序员面试必刷
近几年受疫情影响各行各业的日子都不好过,虽然程序员日子也挺难,但是好在可以线上面试、线上办公,影响还是比较小的,但是去年教育行业的 “双减” 政策,导致又一大批岗位缺失程序员竞争压力突然递升;
|
存储 前端开发 JavaScript
🍪前端笔试系列 | 小米2020校招前端工程师笔试题
🍪前端笔试系列 | 小米2020校招前端工程师笔试题
545 9
🍪前端笔试系列 | 小米2020校招前端工程师笔试题
|
SQL 网络协议 算法
Java后端研发实习生面试知识点总结(持续更新中)
Java后端研发实习生面试知识点总结(持续更新中)
384 0
Java后端研发实习生面试知识点总结(持续更新中)
|
设计模式 运维 Kubernetes
15年老司机聊程序员成长的28个要点
15年老司机聊程序员成长的28个要点
376 1
|
消息中间件 缓存 NoSQL
2022年金三银四,Java后端开发最全面试攻略,程序员求职必看!
时间过的真快,转眼就2022了,现在面临年底裁员,公司跳槽,不论是校招还是社招都避免不了各种面试,如何去准备面试就变得格外重要了,相信一些小伙伴也在为自己的技术,薪资,发展做提升的准备。
190 0
|
供应链
面试宝典(一) - 让你不再错过“金九银十“的求职浪潮之简历包装篇
面试宝典(一) - 让你不再错过“金九银十“的求职浪潮之简历包装篇
150 0
面试宝典(一) - 让你不再错过“金九银十“的求职浪潮之简历包装篇

热门文章

最新文章