程序员面试题精选100题(26)-和为n连续正数序列[算法]
题目:输入一个正数n,输出所有和为n连续正数序列。
例如输入15,由于1+2+3+4+5=4+5+6=7+8=15,所以输出3个连续序列1-5、4-6和7-8。
分析:这是网易的一道面试题。
这道题和本面试题系列的第10题有些类似。我们用两个数small和big分别表示序列的最小值和最大值。首先把small初始化为1,big初始化为2。如果从small到big的序列的和大于n的话,我们向右移动small,相当于从序列中去掉较小的数字。如果从small到big的序列的和小于n的话,我们向右移动big,相当于向序列中添加big的下一个数字。一直到small等于(1+n)/2,因为序列至少要有两个数字。
基于这个思路,我们可以写出如下代码:
	void PrintContinuousSequence(int small, int big);
	
	/////////////////////////////////////////////////////////////////////////
	// Find continuous sequence, whose sum is n
	/////////////////////////////////////////////////////////////////////////
	void FindContinuousSequence(int n)
	{
	      if(n < 3)
	            return;
	
	      int small = 1; 
	      int big = 2;
	      int middle = (1 + n) / 2;
	      int sum = small + big;
	
	      while(small < middle)
	      {
	            // we are lucky and find the sequence
	            if(sum == n)
	                  PrintContinuousSequence(small, big);
	
	            // if the current sum is greater than n, 
	            // move small forward
	            while(sum > n)
	            {
	                  sum -= small;
	                  small ++;
	
	                  // we are lucky and find the sequence
	                  if(sum == n)
	                        PrintContinuousSequence(small, big);
	            }
	
	            // move big forward
	            big ++;
	            sum += big;
	      }
	}
	
	/////////////////////////////////////////////////////////////////////////
	// Print continuous sequence between small and big
	/////////////////////////////////////////////////////////////////////////
	void PrintContinuousSequence(int small, int big)
	{
	      for(int i = small; i <= big; ++ i)
	            printf("%d ", i);
	
	      printf("\n");
	}
相关文章
- 程序员面试题精选100题(06)-整数二进制表示中1的个数[算法]
 - 程序员面试题精选100题(51)-顺时针打印矩阵[算法]
 - 程序员面试题精选100题(23)-跳台阶问题[算法]
 - 程序员面试题精选100题(35)-两链表的第一个公共结点[数据结构]
 - 程序员面试题精选100题(25)-在从1到n的正数中1出现的次数[算法]
 - 程序员面试题精选100题(13)-第一个只出现一次的字符
 - 程序员面试题精选100题(61)-数对之差的最大值[算法]
 - 安庆潜山事业单位面试真题汇总
 - 程序员面试题精选100题(50)-树的子结构[数据结构]
 - 程序员面试题精选100题(15)-含有指针成员的类的拷贝[C/C++/C#]
 
热门推荐
- 程序员面试题精选100题(06)-整数二进制表示中1的个数[算法]
 - 程序员面试题精选100题(51)-顺时针打印矩阵[算法]
 - 程序员面试题精选100题(23)-跳台阶问题[算法]
 - 程序员面试题精选100题(35)-两链表的第一个公共结点[数据结构]
 - 程序员面试题精选100题(25)-在从1到n的正数中1出现的次数[算法]
 - 程序员面试题精选100题(13)-第一个只出现一次的字符
 - 程序员面试题精选100题(61)-数对之差的最大值[算法]
 - 安庆潜山事业单位面试真题汇总
 - 程序员面试题精选100题(50)-树的子结构[数据结构]
 - 程序员面试题精选100题(15)-含有指针成员的类的拷贝[C/C++/C#]
 
