分享阿里巴巴综合算法面试题详解

这道题的大意是:有一个淘宝商户,在某城市有n个仓库,每个仓库的储货量不同,现在要通过货物运输,将每次仓库的储货量变成一致的,n个仓库之间的运输线路围城一个圈,即1->2->3->4->…->n->1->…,货物只能通过连接的仓库运输,设计最小的运送成本(运货量*路程)达到淘宝商户的要求,并写出代码。

解题思路:

假设n个仓库的初始储货量分别为warehouse[1],warehouse[2],…,warehouse[n]
计算平均储货量

 average = (warehouse[1]+warehouse[2]+…+warehouse[n])/n

就算出来了最终的结果中,每个仓库应该有的存量
首先,从仓库1向仓库n运送k;
然后,从1到n-1,依次向下运送某一特定值,使得每一个仓库的余量都为average,剩下的问题就是求总代价的最小值了。

设第0步从1仓库向n仓库(注意因为是圆圈,所以路径长度是1)运出k存量,k可以为负,如果为负数,意味着从n向1运输|k|存量,然后从循环,从(1到n-1),从i仓库向i+1仓库运输,运输的量需要保证i仓库在运输完毕后等于average

    第0步(从仓库1向仓库n运送k):花费代价为 |k|,
    第1步(确保仓库1的余量为average):需要花费代价为

    |warehouse[1]-average-k|

    也就是从1向2伙从2向1运输
    第2步(确保仓库2的余量为average):代价为

    |warehouse[2]+warehouse[1]-average-k-average|=|warehouse[1]+warehouse[2]-2average-k|

    …
    n-1.第n-1步:代价为

    |warehouse[1]+warehouse[2]+…+warehouse[n-1]-(n-1)average-k|

    此时,仓库n剩下的货物量:

    (warehouse[n]+k)+warehouse[1]+warehouse[2]+…+warehouse[n-1]-(n-1)average-k=(warehouse[1]+warehouse[2]+…+warehouse[n])-(n-1)average=average

    刚好也满足,其实这里不用推导,因为平均值是算好的,所以最胡一定是刚好完成的。

总的代价为:

|k|+|warehouse[1]-average-k|+|warehouse[1]+a[2]-2average-k|+…+|warehouse[1]+warehouse[2]+…+warehouse[n-1]-(n-1)average-k|

不妨令sum[i] = warehouse[1]+warehouse[2]+…+warehouse[i]-i*average
则,总代价可表示为:|k|+|sum[1]-k|+|sum[2]-k|+…+|sum[n-1]-k|
这个式子可以看成在水平数轴上寻找一个点k,使得点k到点0,sum[1],sum[2],sum[3],…,sum[n-1]的距离之和最小,显然k应该取这n个数的中位数。至此问题解决。

给出详细注释代码:
 

#include “stdafx.h”

include <iostream>
include <algorithm>
include<string>

using namespace std;

const int X = 100000;
double sum[X],warehouse[X];
int n;

double Abs(double x)
{
return max(x,-x);
}

int _tmain(int argc, _TCHAR* argv[])
{
while(true)
{
double total = 0;
double mid=0;
cout<<”请输入仓库数目:”;
cin>>n;
//读入n个仓库的值,并计算总数
for(int i=1;i<=n;i++)
{
cout<<”请输入第”<<i<<”个仓库的存量:”;
cin>>warehouse[i];
total += warehouse[i];
}
//计算每个仓库应该最终存储的值
double average = total/n;
//计算sum数组
for(int i=1;i<n;i++)
sum[i] = warehouse[i]+sum[i-1]-average;
//排序后打算去中位数
//sort采用半开半闭区间,所以排序为0~n-1
sort(sum,sum+n);
//这个可以自己举个数字就知道了
if(n%2!=0)
{
mid = sum[n/2];
}
else
{
mid=(sum[n/2]+sum[n/2-1])/2;
}
cout<<”应该从1开始,运输”<<mid<<”货物,然后依次保证符合条件即可”<<endl;
double ans = Abs(mid);
for(int i=1;i<n;i++)
ans += Abs(sum[i]-mid);
cout<<”总成本花费是:”<<ans<<endl;
cout<<”———————————————————————————————————“<<endl;
}
return 0;
}

错误之处欢迎留言指出..

时间: 2024-11-08 23:17:36

分享阿里巴巴综合算法面试题详解的相关文章

Twitter算法面试题详解(Java实现)

最近在网上看到一道Twitter的算法面试题,网上已经有人给出了答案,不过可能有些人没太看明白(我也未验证是否正确),现在给出一个比较好理解的答案.先看一下题目. 图1 先看看这个图.可以将方块看做砖.题干很简单,问最多能放多少水.例如,图2就是图1可放的最多水(蓝色部分),如果将一块砖看做1的话,图2就是能放10个单位的水. 图2 再看个例子 图3 图3可以放17个单位的水. 上面每一个图的砖墙用int数组表示,每一个数组元素表示每一列砖墙的砖数(高度),例如,图3用数组表示就是int[] w

算法实践——Twitter算法面试题(积水问题)的线性时间解法

问题描述:在下图里我们有不同高度的挡板.这个图片由一个整数数组所代表,数组中每个数是墙的高度.下图可以表示为数组(2.5.1.2.3.4.7.2).假如开始下雨了,那么挡板之间的水坑能够装多少水(水足够多)呢?   下图是装满水的情况,一个蓝色格子代表一个单位的水.下图中一共装了10个单位的水.     问题分析:   先看看下图,判断哪个单元格的水能留下来.下图中的两个单元格,一个红色的单元格和一个绿色的单元格,哪个单元格的水是溜走了,哪个单元格的水能留下来? 很明显的,上图中的红色单元格的水

数据结构与算法面试题80道

1.把二元查找树转变成排序的双向链表  题目: 输入一棵二元查找树,将该二元查找树转换成一个排序的双向链表. 要求不能创建任何新的结点,只调整指针的指向.    10  / \  6 14  / \ / \ 4 8 12 16  转换成双向链表 4=6=8=10=12=14=16.    首先我们定义的二元查找树 节点的数据结构如下:  struct BSTreeNode {  int m_nValue; // value of node  BSTreeNode *m_pLeft; // lef

算法面试题

1.把二元查找树转变成排序的双向链表 题目: 输入一棵二元查找树,将该二元查找树转换成一个排序的双向链表. 要求不能创建任何新的结点,只调整指针的指向. 10 / \ 6 14 / \ / \ 4 8 12 16 转换成双向链表 4=6=8=10=12=14=16. 首先我们定义的二元查找树 节点的数据结构如下: struct BSTreeNode { int m_nValue; // value of node BSTreeNode *m_pLeft; // left child of nod

java面试题——详解HashMap和Hashtable 的区别_java

一.HashMap 和Hashtable 的区别 我们先看2个类的定义 public class Hashtable extends Dictionary implements Map, Cloneable, java.io.Serializable public class HashMap extends AbstractMap implements Map, Cloneable, Serializable 可见Hashtable 继承自 Dictiionary 而 HashMap继承自Abs

综合布线系统屏蔽技术详解

综合布线系统凭借尖端的技术与智能化设计,具有无与伦比的优越性.综合布线解决方案可以提供完全的端到端的解决方案 包括基于铜线和光纤的解决方案:在设计中选择高性能部件,以达到性能上最完美的匹配:为满足现在及将来的需求 选择UTP.FTP或STP电缆 超五类.六类或将来的七类的铜缆科技及创新的光纤解决方案构成光纤到桌面的信息网络.综合布线解决方案的革新能提供网络足够的可靠性和带宽,使我们始终处于布线技术的最前沿. 综合布线产品无论是非屏蔽系统还是屏蔽系统都有着广泛的使用基础 并可以针对不同用户的不同需

独家 | PHM数据竞赛首个中国夺冠团队经验分享(常用模型&amp;赛题详解&amp;PPT&amp;视频)

昆仑数据首席数据科学家田春华博士演讲视频: 团队成员代表刘家扬演讲视频: 以下内容经数据派THU整理而成: 后台回复关键词"1114",下载两位演讲嘉宾完整版PPT. 昆仑数据首席数据科学家田春华   一.工业大数据背景知识和赛题背景 田春华:竞赛是促进大家研究和交流的一种机制,而各个赛事侧重点不同.在KDD-CUP竞赛中,题目相对通用,对于参赛人员的门槛较低,因此会有大量的队伍参加,最后的前几名基本上是小数点后两位或三位的比拼.而PHM侧重于工业行业,一般会描述一个相对具体的问题,参

一道算法面试题

问题描述 有4个彩色的立方体.立方体的6个面,每面都涂上了1种颜色.一共有4种颜色,蓝色(B),红色(R),绿色(G)和黄色(Y).立方体的6个面称为前(front).后(back).左(left).右(right).上(top).下(bottom).这4个立方体的颜色排列为:编号frontbackleftrighttopbottom1RBGYBY2RGGYBB3YBRGYR4YGBRRR请将这4个立方体重叠摆放成为一个立柱,这个立柱有4个侧面,要求每个侧面都有4种颜色.用你最拿手的语言编程实现

网吧综合布线方案实施详解

网吧综合布线方案有很多值得学习的地方,这里我们主要介绍网吧电源系统综合布线验收,包括介绍网络系统综合布线.网络系统综合布线设计等方面,希望对网吧设计人员有所帮助.网吧电源系统综合布线验收 网吧电源系统的网吧综合布线方案工作结束之后,必须进行验收.加之布线工作结束之后,一些管道和装修要继续进行,如果网吧装修结束后发现供电系统有故障,那时的维修成本太大了.为此,网吧电源系统综合布线的验收工作不容马虎.电源布线的验收,通常包括以下几个方面:1.测试所有设备工作是否正常:网吧电源布线工作结束后,必须测试