`
thinke365
  • 浏览: 51840 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

阿里巴巴笔试题_身高排队问题

阅读更多
12个高矮不同的人,排成两排,每排必须是从矮到高排列,而且第二排比对应的第一排的人高,问排列方式有多少种?

假定这12个人各自有自己的编号,即1、2、3... 11、12. 并且编号1到编号12所代表的人身高是递增的。
解这道题基于观察发现的如下规律:
a、第一排第一个人必定是1.
b、第一排第二个位置的可选值是2、3,第一排第三个位置的可选值是3、4、5,...,第一排第6个人的可选值是6、7、8、9、10、11
c、第一排的数字确定后,第二排的顺序可以唯一确定。因为剩下的6个数字只能递增排列(显然只有一种结果),所以只需确定第一排的所有排列可能就行了。 如下是解题的最初实现方法。采用穷举法实现。

#include <iostream>
using namespace std;

#include <vector>
#include <set>

// 后来发现不需要记录路径中现有节点。因为数字本身存在偏序的问题,往上涨就行了
set<int> path;
vector<vector<int>> marks;

int getCount(int depth, int max)
{
	if(depth==marks.size()) {
		int flag=0;
		for(int i=0; i<marks[depth-1].size(); i++) {
			// path.find(marks[depth][i]) == path.end() &&
			if( marks[depth-1][i]>max) {
				flag ++;
			}
		}
		return flag;
	}
	int count = 0;
	for(int i=0;i<marks[depth-1].size();i++) {
		if( marks[depth-1][i]>max) {
			count += getCount(depth+1,marks[depth-1][i]);
		}
	}
	return count;
}


int main()
{
	int n;
	while(cin>>n) {
		

		marks.clear();
		for(int i=1; i<=n/2; i++) {
			vector<int> node;
			for(int j=0;j<i;j++) {
				node.push_back(i+j);
			}
			marks.push_back(node);
		}

		cout << getCount(1, 0) << endl;



	}
	return 0;
}
.
分享到:
评论
8 楼 GC_Man 2009-11-10  
我不太懂算法,上来学习下。
大家看这样行不,先排好第一排。完全按从矮到高。然后只要从第二个开始遍历。随即抽6个人到第二排。统计下可能的次数就可以了吧。
各位大哥看我这样的算法可以不,纯粹提疑问加学习,欢迎指导
7 楼 BenArfa 2009-11-04  
gembler 写道
BenArfa 写道
(12,6)/7 = 132
如果对数学解释感兴趣的话我可以贴出来分析过程,写起来有几句话的

愿闻其详

阁下晚上好,这题大体思路是这样的
如果要满足题意,只要从12个人中挑选6个人放在第一排,那么所有的人的位置就都确定了,因为是要求按身高排序的。
这里我们的挑选方法以及限制条件是这样的:12个人先从矮到高排序,然后每个人被选到第一排或者第二排,如果要满足题意,当且仅当每挑选完一次之后,第二排中的人数不多于第一排中的人数。

而这个条件的排列就是(12,6)-(12,5)。
6 楼 gembler 2009-11-04  
BenArfa 写道
(12,6)/7 = 132
如果对数学解释感兴趣的话我可以贴出来分析过程,写起来有几句话的

愿闻其详
5 楼 BenArfa 2009-11-03  
(12,6)/7 = 132
如果对数学解释感兴趣的话我可以贴出来分析过程,写起来有几句话的
4 楼 20.Shadow 2009-10-28  
引用楼主思路的Erlang代码 (testCalc.erl) :

-module(testCalc). 
-export([test/0]).

test() ->
L1 = [[A1, A2, A3, A4, A5, A6] ||
A1 <- [1],
A2 <- [2, 3],
A3 <- [3, 4, 5],
A4 <- [4, 5, 6, 7],
A5 <- [5, 6, 7, 8, 9],
A6 <- [6, 7, 8, 9, 10, 11],
A2 > A1,
A3 > A2,
A4 > A3,
A5 > A4,
A6 > A5
],
print(L1),
io:format("Len = ~p", [length(L1)]).

print ([]) ->
null;
print([H | T]) ->
Arr = [2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12],
L2 = lists:filter(fun(E) -> R = lists:member(E, H), not R end, Arr),
io:format("L1 = ~p, L2 = ~p~n", [H, L2]),
print(T).

132个结果 - Right.
3 楼 fruitking 2009-10-27  
我也从新整理了一下
http://fruitking.iteye.com/blog/505037
java版本的
我采用的是栈操作来遍历
有详细分析解决过程
2 楼 chinpom 2009-10-27  
<p><strong>我是用状态生成树的方式来做的,先把12个人按从低到高一次编号,从(1 ; 2)出发,加入3和4的时候生成(1,3 ; 2,4)和(1,2 ; 3,4),然后加入5和6,分别从前面的两个状态出发,可以生成5种状态,就是说6个人时有5种排列。最好是画出状态生成树,就很容易写出代码了,核心代码有十几行,全部代码如下:</strong></p>
<pre name="code" class="java">import java.util.ArrayDeque;
import java.util.Deque;

public class TwoOrderQueue {

private int count = 0;
private int total = 0;
private Deque&lt;Integer&gt; place = new ArrayDeque&lt;Integer&gt;();

public TwoOrderQueue(int total) {
this.total = total;
}

private void firstOrder(int order, int level) {
place.add(order);
if (level &gt;= total / 2) {
count++;
for (Integer i : place)
System.out.print(i + " ");
System.out.println();
place.pollLast();
return;
}

for (int i = order + 1; i &lt; 2 * (level + 1); i++)
firstOrder(i, level + 1);
place.pollLast();
}

public void firstOrder() {
firstOrder(1, 1);
System.out.println("第一排一共有" + count + "种排列");
}

public static void main(String[] args) {
TwoOrderQueue q = new TwoOrderQueue(12);
q.firstOrder();
}
}</pre>
<p> <strong>当有12个人时,一共输出132种排列。</strong></p>
<p> </p>
<p>顺便向楼主打听一下,阿里的笔试情况怎么样?难不难?我想毕业后回浙江,就是不知道能不能进阿里。现在大四上个学期还有几门专业课,特别是数字信号处理很难,现在在上的考查课《人工智能导论》对解这类题目的帮助挺大的,<img src="/images/smiles/icon_mad.gif" alt=""> 就是来上课的同学越来越少了。</p>
1 楼 seraphim871211 2009-10-26  
嗯,不错,回溯就可以了

相关推荐

    阿里巴巴笔试面试大全

    整理了一下阿里巴巴往届笔试面试题,希望对大家有帮助: 来源:阿里巴巴笔试面试圈&gt;&gt; 1、史上最全Java面试266题:算法+缓存+TCP+JVM+搜索+分布式+数据库 2、2018阿里软件工程师笔试题 3、2018秋招阿里巴巴java...

    阿里巴巴_2014_用户体验研究专员_实习生_笔试题

    ### 阿里巴巴2014年用户体验研究专员实习生笔试题解析 #### 知识点一:加权算术平均数中权重的实质 在统计学中,**加权算术平均数**是一种计算平均值的方法,它考虑了每个数值的重要性或频率,即权重。权重反映了...

    2014年阿里巴巴笔试题

    阿里巴巴作为全球知名的互联网巨头,其笔试题历来备受关注,尤其是对于有意进入IT行业,特别是技术研发领域的求职者来说,这些题目往往能反映出企业对技术人才的基本要求和期望。2014年的阿里巴巴笔试题,虽然已经...

    阿里巴巴校园招聘笔试面试题淘宝校园招聘笔试试题27个文档资料合集.zip

    阿里巴巴校园招聘笔试面试题淘宝校园招聘笔试试题27个文档资料合集: 2012阿里巴巴校园招聘阿里云C++笔试试题.doc 2013年阿里巴巴校园招聘笔试试题研发工程师.doc 2014年3月阿里巴巴实习招聘笔试题及部分答案.docx ...

    csdn上阿里巴巴笔试题汇总(实习生 校招)

    这份“csdn上阿里巴巴笔试题汇总”是一个宝贵的资源,可以帮助备考者了解并准备阿里巴巴的招聘流程。 首先,我们需要明白,阿里巴巴笔试题的核心部分是编程题,这部分通常包括但不限于C++、Java、Python等主流编程...

    阿里巴巴笔试真题合集.rar

    阿里巴巴作为中国领先的互联网巨头,其招聘过程中的笔试环节备受关注。这份“阿里巴巴笔试真题合集”涵盖了该公司在招聘过程中可能会出现的各种试题,旨在考察应聘者的综合素质和技术能力。以下是根据标题、描述和...

    阿里巴巴校招前端笔试题

    阿里巴巴校招前端笔试题 校招前端笔试题.pages

    阿里巴巴笔试题打包

    为了一窥阿里巴巴笔试题的奥秘,我们将深入解析可能涉及的知识点以及如何准备应对此类挑战。 首先,回顾2009年9月在南京进行的阿里巴巴笔试题目,我们不难发现,即使时间已经过去多年,试题中涉及的核心内容至今仍...

    阿里巴巴技术类笔试题2_3卷(测试工程师_公共题)

    阿里巴巴技术类笔试题2_3卷(测试工程师_公共题)

    阿里巴巴笔试题大全

    阿里巴巴笔试题大全,包含近年笔试面试题,对程序员求职非常有用,物超所值

    2014年阿里巴巴实习生笔试题

    文档是2014年阿里巴巴实习生笔试题。各个岗位的基础题是一样的,只是附加题不一样

    09阿里巴巴笔试题.rar

    【阿里巴巴笔试题解析】 阿里巴巴作为全球知名的互联网科技公司,其招聘流程中的笔试环节往往涉及到多元化的IT知识,旨在考察候选人的技术功底、逻辑思维以及问题解决能力。本压缩包"09阿里巴巴笔试题.rar"可能包含...

    阿里巴巴笔试真题

    秋招的时候自己搜集的资料,阿里巴巴的笔试真题,可以参考一下

    javamianshiti.rar_C 笔试题_java 试题_java笔试题_java面试_笔试

    4. **java面试**:意味着除了笔试题外,还可能包含面试常问问题,如项目经验、设计模式、多线程、JVM原理等。 5. **笔试**:再次强调了这个资源的主要目的是帮助用户准备技术笔试环节。 【压缩包子文件的文件名称...

    2009年 阿里巴巴笔试题

    2009年 阿里巴巴笔试题,共分A卷、B卷、C卷三个部分,A卷为java部分。B卷是C++部分,C卷是公共题

Global site tag (gtag.js) - Google Analytics