Fork me on GitHub

04 2012 档案

摘要:题目:有25匹马,一个5道的赛马场,最少比赛几次,能把这25匹马中的1,2,3名找出来,并排出1,2,3名?如何组织每次比赛?马可以重复赛,不考虑疲倦影响速度等其他问题。思路:首先肯定,25匹要分组赛。最容易掉入,也最容易识别的陷阱就是:5匹一组,赛5次,然后每组第一名再赛一次,总共六次,就ok了。这样的问题就在于又可能某组的第二名比其他4组的第一名都快。进而想到最坏的 可能就是,分组的时候把真正的前三名分到同一组了。问题的关键变成了第6次以后应该怎么挑选再赛的马5分钟左右,应该就能想到下面的正确思路。前6次就按照刚才的赛法,5次小组赛,一次各小组第一名赛,然后按各小组第一名在第六次比赛中的名 阅读全文
posted @ 2012-04-09 15:24 浪飞-louffy 阅读(2159) 评论(0) 推荐(0)
摘要:题目:已知一个数组a[N],构造一个数组b[N],构造规则:b[i]=a[0]*a[1]*a[2]...a[N]/a[i]; 要求: 1、不可以使用除法; 2、时间复杂度为O(n),空间复杂度为S(0); 3、除遍历使用的变量外,不可以使用其它变量;从前往后扫一遍,然后从后往前再扫一遍。也就是说,线性时间构造两个新数组,B[i]=A[1]*A[2]*...*A[i],A[i]=A[n]*A[n-1]*...*A[i]。于是,B[i]=B[i-1]*A[i+1]。i=N和0特殊处理#include<stdio.h> int main() { int i, a[5]={... 阅读全文
posted @ 2012-04-09 14:46 浪飞-louffy 阅读(344) 评论(0) 推荐(0)
摘要:卡特兰数h(n)=C(2n,n)/(n+1) (n=1,2,3,...) 前几项为 (OEIS中的数列A000108): 1, 1, 2, 5, 14, 42, 132, 429, 1430, 4862, 16796, 58786, 208012, 742900, 2674440, 9694845, 35357670, 129644790, 477638700, 1767263190, 6564120420, 24466267020, 91482563640, 343059613650, 1289904147324, 4861946401452, ...1,括号化 矩阵链乘: P=a1 阅读全文
posted @ 2012-04-08 22:37 浪飞-louffy 阅读(395) 评论(0) 推荐(0)
摘要:时间复杂度nlogn,空间复杂度nlmin[k]表示前i个元素中长度为k的所有递增子序列的最后一个元素的最小值。#include<stdio.h>#define N 10 int lmin[10]; //找到==或者大于e的第一个数的位置 int bsearch(int a[],int p,int r,int e) { int m; while(p<=r) { m=(p+r)>>1; if(a[m]>e)r=m-1; else if(a[m]<e)p=m+1; else return m; } return p;//返回大于的第一个数位置 //retu 阅读全文
posted @ 2012-04-08 22:01 浪飞-louffy 阅读(162) 评论(0) 推荐(0)
摘要:1,循环链表方法建立一个具有n个链结点,无头结点的循环链表;确定第1个报数人的位置;不断地从链表中删除链结点,直到链表为1结点。2,数组模拟,出去的置03,数学方法,只能输出最后的代码1/* 1,构建循环链表 l为为结点 p为头结点 p=l-》next; 2,循环删除,直到剩下最后一个结点 while(p-》next=p) 删除s,p-》next=s p-》next=s-》next; free(s); s=p-》next; */ #include<stdio.h> #define N 3 struct node{ int a; struct node *next; }; int m 阅读全文
posted @ 2012-04-03 15:52 浪飞-louffy 阅读(160) 评论(0) 推荐(0)