- 浏览: 919604 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (537)
- Java SE (114)
- Struts (18)
- Hibernate (25)
- Spring (3)
- Page_Tech (41)
- Others (87)
- Database (29)
- Server (24)
- OpenSource_Tools (15)
- IDE_Tool (22)
- Algorithm (28)
- Interview (22)
- Test (28)
- Hardware (1)
- Mainframe (25)
- Web application (4)
- Linux (3)
- PHP (17)
- Android (1)
- Perl (6)
- ubuntu (1)
- Java EE (9)
- Web Analysis (5)
- Node.js (2)
- javascript (2)
最新评论
-
一键注册:
request.getRequestURL()和request.getRequestURI() -
SuperCustomer:
...
SED的暂存空间和模式空间 -
juyo_ch:
讲得挺好理解的,学习了
java 死锁及解决 -
chinaalex:
最后一题答案正确,但是分析有误.按照如下过程,上一行为瓶,下一 ...
zz智力题 -
liaowuxukong:
多谢博主啦,弱弱的了解了一点。
C++/Java 实现多态的方法(C++)
题目:输入一个整形数组,数组里有正数也有负数。数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和。求所有子数组的和的最大值。要求时间复杂度为O(n)。
例如输入的数组为1, -2, 3, 10, -4, 7, 2, -5,和最大的子数组为3, 10, -4, 7, 2,因此输出为该子数组的和18。
分析:本题最初为2005年浙江大学计算机系的考研题的最后一道程序设计题,在2006年里包括google在内的很多知名公司都把本题当作面试题。由于本题在网络中广为流传,本题也顺利成为2006年程序员面试题中经典中的经典。
如果不考虑时间复杂度,我们可以枚举出所有子数组并求出他们的和。不过非常遗憾的是,由于长度为n的数组有O(n2)个子数组;而且求一个长度为n的数组的和的时间复杂度为O(n)。因此这种思路的时间是O(n3)。
很容易理解,当我们加上一个正数时,和会增加;当我们加上一个负数时,和会减少。如果当前得到的和是个负数,那么这个和在接下来的累加中应该抛弃并重新清零,不然的话这个负数将会减少接下来的和。基于这样的思路,我们可以写出如下代码。
参考代码:
- /////////////////////////////////////////////////////////////////////////////
- // Find the greatest sum of all sub-arrays
- // Return value: if the input is valid, return true, otherwise return false
- /////////////////////////////////////////////////////////////////////////////
- bool FindGreatestSumOfSubArray
- (
- int *pData, // an array
- unsigned int nLength, // the length of array
- int &nGreatestSum // the greatest sum of all sub-arrays
- )
- {
- // if the input is invalid, return false
- if((pData == NULL) || (nLength == 0))
- return false;
- int nCurSum = nGreatestSum = 0;
- for(unsigned int i = 0; i < nLength; ++i)
- {
- nCurSum += pData;
- // if the current sum is negative, discard it
- if(nCurSum < 0)
- nCurSum = 0;
- // if a greater sum is found, update the greatest sum
- if(nCurSum > nGreatestSum)
- nGreatestSum = nCurSum;
- }
- // if all data are negative, find the greatest element in the array
- if(nGreatestSum == 0)
- {
- nGreatestSum = pData[0];
- for(unsigned int i = 1; i < nLength; ++i)
- {
- if(pData > nGreatestSum)
- nGreatestSum = pData;
- }
- }
- return true;
- }
/////////////////////////////////////////////////////////////////////////////
// Find the greatest sum of all sub-arrays
// Return value: if the input is valid, return true, otherwise return false
/////////////////////////////////////////////////////////////////////////////
bool FindGreatestSumOfSubArray
(
int *pData, // an array
unsigned int nLength, // the length of array
int &nGreatestSum // the greatest sum of all sub-arrays
)
{
// if the input is invalid, return false
if((pData == NULL) || (nLength == 0))
return false;
int nCurSum = nGreatestSum = 0;
for(unsigned int i = 0; i < nLength; ++i)
{
nCurSum += pData;
// if the current sum is negative, discard it
if(nCurSum < 0)
nCurSum = 0;
// if a greater sum is found, update the greatest sum
if(nCurSum > nGreatestSum)
nGreatestSum = nCurSum;
}
// if all data are negative, find the greatest element in the array
if(nGreatestSum == 0)
{
nGreatestSum = pData[0];
for(unsigned int i = 1; i < nLength; ++i)
{
if(pData > nGreatestSum)
nGreatestSum = pData;
}
}
return true;
}
讨论:上述代码中有两点值得和大家讨论一下:
· 函数的返回值不是子数组和的最大值,而是一个判断输入是否有效的标志。如果函数返回值的是子数组和的最大值,那么当输入一个空指针是应该返回什么呢?返回0?那这个函数的用户怎么区分输入无效和子数组和的最大值刚好是0这两中情况呢?基于这个考虑,本人认为把子数组和的最大值以引用的方式放到参数列表中,同时让函数返回一个函数是否正常执行的标志。
· 输入有一类特殊情况需要特殊处理。当输入数组中所有整数都是负数时,子数组和的最大值就是数组中的最大元素。
发表评论
-
IGT JAVA Test
2012-06-18 10:18 01. static synchronized vs synch ... -
zz IBM 面试问题
2012-05-30 14:31 9741.JAVA内存回收机制 2.抽象类与接口的区别 3. ... -
面试的准备与发挥
2012-04-26 10:00 879面试是一场智力的较 ... -
栈内存和堆内存
2010-10-21 11:55 803堆:顺序随意栈:先进 ... -
淘宝面试的几个算法题
2010-10-21 11:27 1484一、给你1副扑克牌,你 ... -
程序员面试题精选(18)-用两个栈实现队列
2010-10-18 22:45 1101题目:某队列的声明如下: C++代码 t ... -
程序员面试题精选(17)-把字符串转换成整数
2010-10-18 22:44 1009题目:输入一个表示整 ... -
程序员面试题精选(16)-O(logn)求Fibonacci数列
2010-10-18 22:41 1846题目:定义Fibonacci数列如下: / ... -
程序员面试题精选(15)-含有指针成员的类的拷贝
2010-10-18 22:41 895题目:下面是一个数组类的声明与实现。请分析这个类有什么问题,并 ... -
程序员面试题精选(14)-圆圈中最后剩下的数字
2010-10-18 22:40 1464题目:n个数字(0,1,…,n-1)形成一个圆圈,从数字0开始 ... -
程序员面试题精选(13)-第一个只出现一次的字符
2010-10-18 22:38 922题目:在一个字符串中找到第一个只出现一次的字符。如输入abac ... -
程序员面试题精选(12)-从上往下遍历二元树
2010-10-18 22:37 976题目:输入一颗二元树,从上往下按层打印树的每个结点,同一层中按 ... -
程序员面试题精选(11)-求二元查找树的镜像
2010-10-18 22:36 1352题目:输入一颗二元查 ... -
程序员面试题精选(10)-在排序数组中查找和为给定值的两个数字
2010-10-18 22:33 1044题目:输入一个已经按升序排序过的数组和一个数字,在数组中查找两 ... -
程序员面试题精选(09)-查找链表中倒数第k个结点
2010-10-18 22:32 1151题目:输入一个单向链表,输出该链表中倒数第k个结点。链表的倒数 ... -
程序员面试题精选(08)-求1+2+...+n
2010-10-18 22:31 988题目:求1+2+…+n,要求不能使用乘除法、for、while ... -
程序员面试题精选(07)-翻转句子中单词的顺序
2010-10-18 22:30 1181题目:输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺 ... -
程序员面试题精选(06)-判断整数序列是不是二元查找树的后序遍历结果
2010-10-18 22:27 791题目:输入一个整数数 ... -
程序员面试题精选(05)-查找最小的k个元素
2010-10-18 22:24 1446题目:输入n个整数,输出其中最小的k个。 例如输入1,2,3, ... -
程序员面试题精选(04)-在二元树中找出和为某一值的所有路径
2010-10-18 22:22 860题目:输入一个整数和一棵二元树。从树的根结点开始往下访问一直到 ...
相关推荐
根据提供的信息,我们可以总结出两个主要的编程面试题目及其解决方案,分别是求子数组的最大和以及查找最小的k个元素。 ### 1. 求子数组的最大和 #### 题目描述 输入一个整型数组,数组里包含正数和负数。要求找出...
### 知识点一:求子数组的最大和 #### 题目背景及解析 - **题目描述**:给定一个包含正数和负数的整数数组,找到连续的一个或多个整数(即子数组),使得这些整数组成的子数组的和最大。要求时间复杂度为O(n)。 - ...
求子数组的最大和 - **算法原理**:可以使用动态规划的思想来解决这个问题,定义一个状态数组dp[i]表示以第i个元素结尾的最大子数组和。 - **状态转移方程**:对于任意位置i,都有dp[i] = max(dp[i-1]+nums[i], ...
3. **求子数组的最大和** - 问题可以转化为寻找所有连续子数组中的最大和,使用Kadane's algorithm可以在O(n)时间内找到。 4. **在二元树中找出和为某一值的所有路径** - 使用深度优先搜索(DFS)或广度优先搜索...
3. **求子数组最大和** - 使用Kadane's Algorithm,维护一个当前子数组的和以及全局最大和。遍历数组,每次更新当前子数组和,若当前元素比子数组和大,就重新开始子数组,否则保留当前子数组。最后返回全局最大和...
求子数组的最大和 #### 题目解析: 给定一个包含正负整数的数组,求其中连续子数组的最大和。 #### 解题思路: 可以使用**动态规划**的方法来解决这个问题。定义一个变量`maxSoFar`表示目前为止遇到的最大子数组...
【算法面试题21】是针对程序员面试时常见的算法题目集合,主要考察的是思维能力和算法应用。以下将详细解析这些题目: 1. **二元查找树转双向链表**: 这个问题要求将一棵二元查找树(BST)转换成一个有序的双向...
4. 求子数组的最大和:这是一个经典的动态规划问题,也称为最大子序列和问题。算法核心是计算到当前元素为止的子数组和,如果发现和为负值,则抛弃。 5. 在二元树中找出和为某一值的所有路径:这是一个递归遍历二元...
【微软编程面试100题】是一系列针对程序员面试的挑战题目,涵盖了数据结构和算法等领域,旨在评估候选人的编程能力和逻辑思维。以下是其中几道题目的解析: 1. **二元查找树转双向链表**: 这道题要求将一个二元...