日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

某公司的一道机考题的解答

發布時間:2025/4/5 编程问答 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 某公司的一道机考题的解答 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

???? 昨天看到某個公司招聘出的一道題目,題目是這樣的:判斷任意三個點是否構成三角形,以及某個點是否位于指定的三角形內。
??? 關于這個問題,我給出了自己的答案,首先解決第一個問題:
???

??????? ///?<summary>
????????
///?IsTriangle?判斷集合中的頭三個點PointF是否可以構成一個三角形
????????
///?</summary>????????
????????public?static?bool?IsTriangle(ArrayList?ptList)
????????{
???????????
?PointF?pt0?=?(PointF)ptList[0]?;
????????????PointF?pt1?
=?(PointF)ptList[1]?;
????????????PointF?pt2?
=?(PointF)ptList[2]?;

?????????????//如果有兩個點相同
????????????
if(pt0.Equals(pt1)?||?pt0.Equals(pt2)?||?pt1.Equals(pt2)?)
????????????{
????????????????
return?false?;
????????????}

????????????
float?length_01?=?(float)Math.Sqrt((pt0.X?-?pt1.X)*(pt0.X?-?pt1.X)?+?(pt0.Y?-?pt1.Y)*(pt0.Y?-?pt1.Y))?;
????????????
float?length_02?=?(float)Math.Sqrt((pt0.X?-?pt2.X)*(pt0.X?-?pt2.X)?+?(pt0.Y?-?pt2.Y)*(pt0.Y?-?pt2.Y))?;
????????????
float?length_12?=?(float)Math.Sqrt((pt2.X?-?pt1.X)*(pt2.X?-?pt1.X)?+?(pt2.Y?-?pt1.Y)*(pt2.Y?-?pt1.Y))?;

????????????
bool?result0?=?(length_01+length_02?<=?length_12)??;
????????????
bool?result1?=?(length_01+length_12?<=?length_02)??;
????????????
bool?result2?=?(length_02+length_12?<=?length_01)??;

????????????
if(result0?||?result1?||?result2)
????????????{
????????????????
return?false?;
????????????}

????????????
return?true?;
????????}

??? 該解答分為兩步,首先判斷是否有重點,接著以兩邊之和大于第三邊作為構成三角形的依據。

??? 關于第二個問題稍微復雜些,不過幸好我在早期研究過并解決了一個更常見的問題,那就是判斷一個點是否位于某個多邊形內,而且即使這個多邊形是凹多邊形。這個功能在EnterpriseServerBase.XMath.Geometry.Polygon類中實現。
??? 對于問題二的解答,我封裝了Triangle類,它不僅借助Polygon類解決了問題二,而且可以計算三角形的面積和各個邊長。

public?class?Triangle
{
????????
private?ArrayList?vertextList?=?null?;
????????
private?ArrayList?lengthList??=?null?;
????????
private?float?myArea?=?0?;

???????ctor#region?ctor
????????
public?Triangle(ArrayList?ptList)
????????
{????????????
????????????
if(!?GeometryHelper.IsTriangle(ptList))
????????????
{
????????????????
throw?new?ArgumentException("The?points?in?list?can't?construct?a?triangle?!")?;
????????????}


????????????
this.vertextList?=?ptList?;
????????????
this.FillLengthList()?;
????????}


????????
public?Triangle(PointF?pt0?,PointF?pt1?,PointF?pt2)
????????
{????
????????????ArrayList?ptList?
=?new?ArrayList()?;
????????????ptList.Add(pt0)?;
????????????ptList.Add(pt1)?;
????????????ptList.Add(pt2)?;

????????????
if(!?GeometryHelper.IsTriangle(ptList))
????????????
{
????????????????
throw?new?ArgumentException("The?points?in?list?can't?construct?a?triangle?!")?;
????????????}


????????????
this.vertextList?=?ptList?;
????????????
this.FillLengthList()?;
????????}


????????
private?void?FillLengthList()
????????
{
????????????PointF?pt0?
=?(PointF)this.vertextList[0]?;
????????????PointF?pt1?
=?(PointF)this.vertextList[1]?;
????????????PointF?pt2?
=?(PointF)this.vertextList[2]?;????????

????????????
float?length_01?=?(float)Math.Sqrt((pt0.X?-?pt1.X)*(pt0.X?-?pt1.X)?+?(pt0.Y?-?pt1.Y)*(pt0.Y?-?pt1.Y))?;
????????????
float?length_02?=?(float)Math.Sqrt((pt0.X?-?pt2.X)*(pt0.X?-?pt2.X)?+?(pt0.Y?-?pt2.Y)*(pt0.Y?-?pt2.Y))?;
????????????
float?length_12?=?(float)Math.Sqrt((pt2.X?-?pt1.X)*(pt2.X?-?pt1.X)?+?(pt2.Y?-?pt1.Y)*(pt2.Y?-?pt1.Y))?;

????????????
this.lengthList?=?new?ArrayList()?;
????????????
this.lengthList.Add(length_12)?;
????????????
this.lengthList.Add(length_02)?;
????????????
this.lengthList.Add(length_01)?;
????????}


????????
#endregion

????????
Area?,GetEdgeLength#region?Area?,GetEdgeLength
????????
/**////?<summary>
????????
///?Area?三角形的面積
????????
///?</summary>????????

????????public?float?Area
????????
{
????????????
get
????????????
{
????????????????
if(this.myArea?==?0)
????????????????
{
????????????????????
this.myArea?=?this.GetArea()?;
????????????????}


????????????????
return?this.myArea?;
????????????}

????????}
????????

????????
private?float?GetArea()
????????
{
????????????
float?len0?=?(float)this.lengthList[0]?;
????????????
float?len1?=?(float)this.lengthList[1]?;
????????????
float?len2?=?(float)this.lengthList[2]?;

????????????
float?p?=?(len0?+?len1?+?len2)?*?0.5f?;

????????????
return?(float)Math.Sqrt(p?*?(p-len0)?*?(p-len1)?*?(p-len2))?;
????????}



????????
public?float?GetEdgeLength(int?index)//0<=?index?<=2
????????{
????????????
if((index?<0)?||(index?>2))
????????????
{
????????????????
return?0?;
????????????}


????????????
return?(float)this.lengthList[index]?;
????????}

????????
#endregion


????????
Contains#region?Contains
????????
/**////?<summary>
????????
///?Contains?判斷某點是否在三角形內部
????????
///?</summary>????????

????????public?bool?Contains(PointF?pt)
????????
{
????????????Polygon?poly?
=?new?Polygon(this.vertextList)?;
????????????
????????????
return?poly.Contains(pt)?;
????????}

????????
#endregion

????}


??? Polygon類的實現比較復雜,代碼也比較多,源碼就不列出來了,可以點擊這里下載。

?

?

轉載于:https://www.cnblogs.com/zhuweisky/archive/2005/10/16/255836.html

總結

以上是生活随笔為你收集整理的某公司的一道机考题的解答的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 欧美一区二区三区国产 | 欧美精品一区二区在线观看 | 国产精品第一 | 日韩精品91 | 国产毛茸茸 | 精品人妻中文无码av在线 | av一区二区不卡 | 日韩激情视频一区二区 | 亚洲午夜久久久久久久久红桃 | 中文字幕免费在线播放 | 亚洲一区中文字幕 | 99在线播放视频 | 午夜在线观看免费视频 | 动漫毛片 | 欧美成人国产精品高潮 | 亚洲丝袜av | 欧美孕妇性xx | 午夜影院在线播放 | 无码成人精品区一级毛片 | 日韩第三页| 欧美日韩亚洲国产精品 | 国产成年人视频网站 | 日本xxxxxxxxx69 | 久久综合免费 | 91久精品 | 成年人午夜免费视频 | 久久人人爱 | 亚洲乱码国产乱码精品精98午夜 | 厕拍极品 | 亚洲一区中文字幕在线 | 深喉口爆一区二区三区 | 国产精品一区二区不卡 | 日韩视频第一页 | 色视频免费看 | 北条麻纪在线观看aⅴ | 日本孕妇孕交 | 网友自拍第一页 | 国产怡红院 | 国产精品无码永久免费不卡 | 青青草国产一区二区三区 | 女人叫床高潮娇喘声录音mp3 | 免费成人深夜夜国外 | 中出 在线 | 欧美久久视频 | 少妇精品视频 | 欧美一二在线 | 中文字幕在线观看一区二区三区 | 91水蜜桃| 黑人玩弄人妻一区二区三区 | 免费成人深夜小野草 | 女人张开双腿让男人捅 | 亚洲成人黄色在线 | 精品人妻一区二区三区含羞草 | 久在线播放 | 成人依人 | 一区二区三区久久久久 | 在线观看视频中文字幕 | 亚洲a级在线观看 | 黄色欧美网站 | 亚洲一区免费 | 无码一区二区三区 | 欧美三级电影在线观看 | 色伊人影院 | 亚洲精品.www | 久久国产精品久久国产精品 | 亚洲欧美自拍视频 | 一区三区在线观看 | 欧美aaa一级片 | 尤物在线观看视频 | 怡春院在线视频 | 中文字幕一区二 | 午夜啪啪福利 | 在线免费国产 | 中国免费观看的视频 | 四虎影视永久地址 | 偷拍第一页| 国产精品偷伦视频免费看 | 成人动漫免费在线观看 | 亚洲电影一区二区 | 亚洲不卡影院 | 亚洲va视频 | 国产视频在 | 中文字幕欧美视频 | 欧美极品少妇xxxxⅹ喷水 | 国产一区不卡 | 中文字幕+乱码+中文字幕一区 | 欧美高清一区 | 亚洲一区二区福利 | 天天操国产 | 亚洲一级精品 | 国产一区二区视频免费 | 在线免费看黄视频 | 中文字幕一本 | www.四虎com | 不卡日本视频 | 国产第100页| 超碰在线最新地址 | 欧美老少做受xxxx高潮 | av在线免费观看网址 |