自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(19)
  • 资源 (2)
  • 收藏
  • 关注

原创 判断顶点是否位于三角形内

这是一个三维空间中的平面问题,假设三角形的三个顶点为A(xa, ya, za)、B(xb, yb, zb)、C(xc, yc, zc),另外一个顶点为P(xp, yp, zp)。问题:判断顶点 P 是否位于ABC组成的三角形上(内部和边界)。方法1:效率较低的方法。(1) 利用面积判断。如果顶点落在三角形上,那么顶点P分别和ABC三点连接后组成的三个小三角形的面积之和一

2013-07-21 22:09:41 2169

原创 判断顶点是否位于线段上

假设线段的两个端点分别为:A、B,另外一点为 P。方法1:通过线段确定的直线方程判断。(1) 在二维空间中,三点坐标表示为:A(xa,ya), B(xb,yb), P(xp,yp)。AB确定的直线方程(点斜式)为:      y = (x - xa) * (yb - ya) / (xb - xa) + ya。P点若位于直线上,首先应该满足直线的方程:      yp =

2013-07-21 16:47:38 1669

原创 有关struct的构造函数

在 C++ 中,struct 可以同 class 一样拥有自己的成员,只不过 struct 成员的访问默认的是 public 范围。如果在 struct 中定义了构造函数,则默认构造函数(无参构造函数)必须显示定义才能使用。否则,在创建此结构体的实例时,会出现编译错误。struct Test { int a; char* b;};Test* test = new Test; /

2013-03-02 18:03:47 1191

转载 HOOPS 3D可视化入门教程二:模块介绍

出处:http://www.evget.com/zh-CN/info/catalog/17468.html上一个教程中介绍了HOOPS的背景和编译相关的内容,这篇文章将要向大家介绍HOOPS的几大主要模块。上一教程请参见:《HOOPS 3D可视化入门教程一:简介及安装部署》下一教程请参见:《HOOPS 3D可视化入门教程三:基本概念和数据结构》HOOPS是一个模块儿

2013-01-26 12:48:07 1765

转载 HOOPS 3D可视化入门教程三:基本概念和数据结构

出处:http://www.evget.com/zh-CN/info/catalog/17485.html上篇文章介绍了 HOOPS 的主要模块,这篇文章将要向大家介绍HOOPS的数据结构以及穿插其中的一些基本概念。这些内容主要包含在3dGS模块内。《HOOPS 3D可视化入门教程一:简介及安装部署》 《HOOPS 3D可视化入门教程二:模块介绍》一、保留模式H

2013-01-26 12:45:38 3428

转载 HOOPS 3D入门教程一:简介及安装部署

出处:http://www.cnblogs.com/evgetsolutions/archive/2012/09/03/2669079.html用HOOPS做开发也有段时间了,也曾去北京的一家做虚拟现实的公司做过短期的相关技术交流,觉得有必要利用暑假回家休息这段时间来做些总结。HOOPS介绍HOOPS是一个功能齐全性能优良的3D可视化开发套件。追述其历史,可发现一条常见

2013-01-26 12:32:42 3026 1

原创 链表奇偶位置调换

题目:将链表的奇数位和偶数位调换组成新的链表分析:先遍历链表,将链表依据奇数位和偶数位分解成两个链表,然后依次在偶数位链表中的每个结点后面插入奇数位链表中的相应位置的每个结点。定义两个函数,一个是删除链表头结点,另一个是在指定结点后面插入一个节点。重组链表的过程即是删除奇数位链表头结点,然后再将其插入在偶数位链表中指定的位置上。时间复杂度为O(N)/* * 将链表的奇数位和偶数位

2012-10-23 20:56:22 3110 1

原创 计算多边形的面积

题目:输入一个点列,顺次连接成一个封闭多边形,计算多边形的面积分析:方法一,计算面积可以考虑定积分的形式,定积分有正有负,顺次求和,重复部分相互抵消,最后剩下的总面积的绝对值就是多边形的面积。从线性积分后的结果可以容易的看出,直线段的积分实际上就是求该直线段与x轴所围成的区域的梯形的面积Int(P1, P2) = Int(k*x + b, P1.x, P2.x) = 0.5 * (

2012-10-22 15:59:04 968

原创 时针和秒针重合次数

问题:24小时内时针和秒针重合几次分析:此题看似有点吓人,但若想到一点,就可秒杀此题。首先,要明白什么是时针和秒针重合,因为秒针走一秒是钟表中的一格,而时针可以看成是连续的转动,此处重合就要理解为在秒针停下的那一刻重合。想到这点,再看时针若想和秒针重合,必须走到一格时,秒针刚好走到这一格。已知一格有12分钟,时针走到每格时,必是整分钟,也即秒针必定在12点的位置。那么两者若想重合,只有在两者同

2012-10-22 09:02:04 1126

原创 找最大的N个数

题目:找最大的N个数时间限制1000 ms,内存限制256000 kB,代码长度限制8000 B。给定N个整数,找最大的前M个数(不一定有序),要求时间复杂度尽量低。先输入N和M (1 输入示例:5编程题-找最大的N个数354321 输出示例:543分析:1、如果所有的数据都可以装入内存,可以考虑使用快排中的分割函数Par

2012-10-22 00:19:50 1354

原创 有关复制构造函数的改错

题目:以下整型数组类的定义中每个函数有且只有一处错误,找出并改正class ArrayInt {public: ArrayInt(const int *pArray, int size) : m_nSize(size) { assert(size > 0); for (int i = 0; i < size; ++ i) m_pArray[i] = pArray[i];

2012-10-21 01:02:54 541

原创 递归算法查找字符串中相同字符连续出现的最大次数

题目:使用递归算法查找字符串中相同字符连续出现的最大次数举例:输入“aaabbc”,输出3分析:问题实质上是“查找字符串中相同字符连续出现的最大次数”,关键是限制了只允许使用递归的方法。思路:1、非递归的情况:连续字符的问题可以通过设置前后指针,不断移动比较两个指针的值即可解决。int CountMaxNumOfChar(const char *str) { if (str ==

2012-10-20 14:18:42 2707

原创 N个结点可构成多少不同的二叉树

题目:树的形态时间限制1000 ms,内存限制256000 kB,代码长度限制8000 B每行输入一个自然数n,对应输出两行,每行一个数字,分别是:节点为n的二叉树有____种。如果每个节点可能有红、黑两种颜色,有____种。输入示例:12输出示例:1228思路:此题即为Catalan数的应用之一:N个结点可以构成多少不同的二叉树

2012-10-18 15:31:30 4382

原创 判断平衡二叉树

题目:编程题-平衡二叉树时间限制 1000 ms,内存限制 256000 kB,代码长度限制 8000 B判断一个二叉树是不是平衡说明:一棵二叉树任意一个节点的左右子树的深度差不大于1,即为平衡二叉树。给定一个有N个节点的二叉树,每个节点有一个序号表示,树有M条分支。每个分支用三个数字A B C表示,指A节点的左儿子为B,右儿子为C。如果B或C为-1,说明无该儿子。规定树根

2012-10-18 09:46:40 753

原创 模式串查找

题目:给定两个字符串,一个模式串,一个目标串,找出目标串中符合模式串格式的字串举例:str = "aaababaa", format = "XXYXY", 输出:"aabab"思路:将模式串按字符分类,存储每个字符出现的位置,例如:position['X'] = {0, 1, 3}。判断目标串中当前的子串是否符合模式串的格式。若符合,输出;否则,目标串中的指针向后移动一位,继续检查。分

2012-10-16 09:47:12 1274

原创 只同0交换的排序

题目:一个N元数组,乱序存放0~N-1的数字,只允许同数字0所在位置交换,排序整个数组思路:首先找出0所在的位置,将0交换到第0位。从第1位开始依次判断后续的数字x是否放在正确位置,若位置正确,进行后续检查;若位置不正确,将该数字x,该数字x要放位置的数字y及0,三数字进行交换,此后,x换到了正确位置,继续检查y是否正确,直到正确为止。分析:时间复杂度O(N),空间复杂度O(1)

2012-10-16 09:28:02 1167 4

原创 打印前N个素数

题目:打印前N个素数,不需要考虑大数和溢出思路:从2开始,依次检测后续的每个数,若为素数,计数加1,直到计数到N。分析:问题复杂度的瓶颈在于判断一个数是否为素数。鉴于前面的素数已经找出,可以将所有找出的素数保存下来,在判断一个数x是否为素数时,只需判断该数x是否能整除[2,sqrt(x)]内的所有素数即可。/* * 打印前N个素数 * 不需要考虑大数和溢出的情况 * *

2012-10-16 08:30:11 1591

原创 华为机试试题再写

华为机试时,自己由于对一些库函数不熟,写的代码像一坨shit,还未调试通过。回来后恶补一次,再写一遍以下三道试题。试题的难度不大,关键是在一小时内能写出清晰的代码,没有bug,对我有点难度。/*题目一: 字符串的过滤功能1、输入'a'~'z'之间的字符串,去掉重复的字符,如:aaazzz --> az2、pOutputStr在外部已经申请好空间*/void St

2012-09-03 11:39:43 761

原创 LinkIt(持续更新)

站点:StackOverFlow:http://stackoverflow.com/Reddit:http://www.reddit.com/IBM developerWork: https://www.ibm.com/developerworks/cn/Web技术:http://www.w3school.com.cn/java2s: ht

2012-05-22 21:31:58 970

算法导论 中文版

大牛Tomas的一部经典之作,中文版,无数程序员必备的算法书

2011-12-22

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除