twitter面试题内容

“看下面这个图片”

“在这个图片里我们有不同高度的墙。这个图片由一个整数数组所代表,数组中每个数是墙的高度。上边的图可以表示为数组[2,5,1,2,3,4,7,7,6]”

“假如开始下雨了,那么墙之间的水坑能够装多少水呢?”

闲来无事给出一份解决此问题的lua代码(https://gist.github.com/jianchenglee/7262518):

-- author ljc

-- 1) find the max value, split the array to 2 array

-- 2) compute the increment ,get 2 increment array

-- 3) get the result by the increment value(if there are a minus value,then retain water,until one by one accumulation value become plus,then go on next)

waterpool={2,4,3,5,1,2,3,2,3,7,7,6,7,6,4,5}

testcase_1 = {2,5,1,2,3,4,7,7,6}

testcase_2 = {2,5,1,3,1,2,1,7,7,6}

testcase_3 = {6,1,4,6,7,5,1,6,4}

function watertotal(o)

-- v1:tempvalue total: result value


-- v_max,i_max: the biggest value and the index of the input array


-- waterpool_q1: first half increment value array waterpool_q2: secopd half increment value array


local v1,v_max,i_max,total=0,0,0,0,0;


local waterpool_q1={};


local waterpool_q2={};

local allnumber=table.maxn(o)

--1)


for i,v in ipairs(o) do


if v>v_max then


v_max=v


i_max=i


end


end

--2)


-- generate waterpool_q1


for i=1,i_max-1,1 do


--print(o[i]-v1)


table.insert(waterpool_q1,o[i]-v1)


v1=o[i]


end

-- generate waterpool_q2


v1=0


for i=allnumber,i_max,-1 do


--print(o[i]-v1)


table.insert(waterpool_q2,o[i]-v1)


v1=o[i]

end

--3)


-- the result of waterpool_q1


v1=0

for i,v in ipairs(waterpool_q1) do

if v<0 and v1>=0 then


v1=v


total=total+math.abs(v1)


elseif (v1+v<0) then


v1=v1+v


total=total+math.abs(v1)


elseif v+v1>=0 then


v1=0

end


--print(math.abs(v1))


end

-- the result of waterpool_q1


v1=0


for i,v in ipairs(waterpool_q2) do

if v<0 and v1>=0 then


v1=v


total=total+math.abs(v1)


elseif (v1+v<0) then


v1=v1+v


total=total+math.abs(v1)


elseif v+v1>=0 then


v1=0

end


--print(math.abs(v1))


end

print(total)

end

-- test the function

watertotal(waterpool)

watertotal(testcase_1)

watertotal(testcase_2)

watertotal(testcase_3)

测试结果:

>lua -e "io.stdout:setvbuf 'no'" "waterpool.lua" 
17
10
17
13

水池问题的lua语言算法(面试题分析:我的Twitter技术面试失败了)的更多相关文章

  1. 【转载】经典10道c/c++语言经典笔试题(含全部所有参考答案)

    经典10道c/c++语言经典笔试题(含全部所有参考答案) 1. 下面这段代码的输出是多少(在32位机上). char *p; char *q[20]; char *m[20][20]; int (*n ...

  2. Lua语言中文手册 转载自网络

    Programming in LuaCopyright ® 2005, Translation Team, www.luachina.net Programming in LuaProgramming ...

  3. C语言编程规范试题(标准答案)

    C语言编程规范试题(标准答案) 一.单选题(每小题3分,共20小题60分) 1.1-1.5    B D A C B                1.6-1.10    C A D B C 1.11 ...

  4. C语言编程规范试题

    C语言编程规范试题 [说明]: 1.本试题中不考虑头文件引用问题(假定已经包含正确的头文件),C语言的标准函数都可用: 2.如果不特别说明,假定程序运行环境为:操作系统Windows 2000, VC ...

  5. 用VC编译lua源码,生成lua语言的解释器和编译器

    用VC编译lua源码,生成lua语言的解释器和编译器 1.去网址下载源码 http://www.lua.org/download.html 2.装一个VC++,我用的是VC6.0 3.接下来我们开始编 ...

  6. 51CTO专访淘宝清无:漫谈Nginx服务器与Lua语言

    http://os.51cto.com/art/201112/307610.htm 说到Web服务器,也许你第一时间会想到Apache,也许你会想到Nginx.虽然说Apache依然是Web服务器的老 ...

  7. 【quick-cocos2d-x】Lua 语言基础

    版权声明:本文为博主原创文章,转载请注明出处. 使用quick-x开发游戏有两年时间了,quick-x是cocos2d-Lua的一个豪华升级版的框架,使用Lua编程.相比于C++,lua的开发确实快速 ...

  8. lua语言入门之Sublime Text设置lua的Build System

    转自: http://blog.csdn.net/wangbin_jxust/article/details/8911956 最近开始学习LUA语言,使用Sublime Text作为编辑器,不得不说, ...

  9. 编译并使用Lua语言

    Lua是一个小巧的脚本语言,该语言设计的目的是为了嵌入应用程序中,从而为应用程序提供灵活的扩展和定制功能. 可扩展性.Lua的扩展性非常卓越,可以通过Lua代码或C代码扩展,很多功能可以通过外部库来扩 ...

随机推荐

  1. python自学开始

    95年工科女一枚 java工程师算不上,只能说从事java开发相关的工作,由于对Python有着极其浓厚的兴趣,一周时间了解大概之后,决定从今天开始见缝插针自学Python,为了防止本人三天打鱼两天晒 ...

  2. C语言学习第一天~Eclipse MinGW环境搭建

    一.环境准备 windows 二.Windows环境下gcc编译器 1.MinGW介绍         MinGW是指只用自由软件来生成纯粹的Win32可执行文件的编译环境,它是Minimalist ...

  3. 厉害了,PS大神真的能改变世界!

    今天要介绍的这位PS大神 名叫 Katrina Yu 她的操作真的神了 不管多普通的场景 她都能帮你改头换面 在后院破旧的椅子上喝着咖啡 一转眼就骑着魔法扫帚 飞上了天,与月亮肩并肩 看原图还以为是在 ...

  4. How to change and add some params to request in Laravel controller?

    $request->merge([ 'aae_id' => request('id', 0), 'foo' => 'bar', ]);

  5. Maximum Size Subarray Sum Equals k LT325

    Given an array nums and a target value k, find the maximum length of a subarray that sums to k. If t ...

  6. Python Tutor

    Python Tutor Python Tutor 是由 Philip Guo 开发的一个免费教育工具,可帮助学生攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程.通过这个工具, ...

  7. 【Erlang】源码安装

    Erlang介绍 Erlang(['ə:læŋ])是一种通用的面向并发的编程语言,它由瑞典电信设备制造商爱立信所辖的CS-Lab开发,目的是创造一种可以应对大规模并发活动的编程语言和运行环境. Erl ...

  8. KM匹配板子

    /* gyt Live up to every day */ #include<cstdio> #include<cmath> #include<iostream> ...

  9. java:static详解

    1.static修饰的变量习惯称为静态变量,static修饰的方法称为静态方法,static修饰的代码块叫做静态代码块. 1)static变量 static变量也称作静态变量,静态变量和非静态变量的区 ...

  10. unity实现一个物体绕着某点旋转

    transform.RotateAround(o.transform.position,Vector3.up,20*Time.deltaTime);transform.Rotate(Vector3.u ...