分享一道筆試題[有n個(gè)直線最多可以把一個(gè)平面分成多少個(gè)部分]
<html>
題:<br />
有n個(gè)直線最多可以把一個(gè)平面分成多少個(gè)部分<br /><br />
線條數(shù):<input type="text" id="line"/><br />
內(nèi)交點(diǎn):<label id="innerPoint"></label><br />
分割數(shù):<label id="part" style="background:yellow;"></label><br />
<input type="button" onclick="calculate()" value="計(jì)算"/>
</html>
<script type="text/javascript">
function calculate(line)
{
var line = document.getElementById('line').value;
if(line == "")
{
line = 0;
document.getElementById('line').value = line;
}
var line = parseInt(line);
var innerPoint = line * (line -1) / 2;
var part = (Math.pow(line,2) + line)/2 + 1;//line + innerPoint + 1等于(線條數(shù)的平方+線條數(shù))/2 + 1
document.getElementById('innerPoint').innerText = innerPoint;
document.getElementById('part').innerText = part;
}
</script>
說(shuō)一下規(guī)律:
①最多分成的部分:線條數(shù)+內(nèi)交點(diǎn)數(shù)+1
②內(nèi)交點(diǎn)數(shù)=(線條數(shù)-1)的內(nèi)交點(diǎn)數(shù)+(線條數(shù)-1),新添加的線條可以會(huì)與除他之外的線條有交點(diǎn)
③用遞歸求出內(nèi)交點(diǎn)數(shù),然后代入①計(jì)算
上面是正常的數(shù)學(xué)思維,下面說(shuō)說(shuō)我用的行測(cè)知識(shí),就是我代碼的東東
我列出了1~5條直線一些可用的參數(shù):
直線數(shù) 內(nèi)交點(diǎn) 外交點(diǎn) 部分?jǐn)?shù)
1 0 2 2
2 1 4 4
3 3 6 7
4 6 8 11
5 10 10 16
發(fā)現(xiàn),外交點(diǎn)是沒(méi)有意義的,反正都是直線數(shù)的2倍
而部分?jǐn)?shù)=直線數(shù)+內(nèi)交點(diǎn)數(shù)+1
相鄰直線個(gè)數(shù)內(nèi)交點(diǎn)個(gè)數(shù)組成一個(gè)等差數(shù)列,這個(gè)等差數(shù)列公差為1, 1-0=1,3-1=2,6-3=3,10-6=4, 橫向看1+0=1,2+1=3,3+3=6...但是這樣還是用到了遞歸要求出上一個(gè)對(duì)應(yīng)的內(nèi)交點(diǎn)個(gè)數(shù),于是縱向看規(guī)律,2*1=2 3*2=6 4*3=12...正好是內(nèi)交點(diǎn)個(gè)數(shù)的2倍
相關(guān)文章
JavaScript 解決ajax中parsererror錯(cuò)誤案例詳解
這篇文章主要介紹了JavaScript 解決ajax中parsererror錯(cuò)誤案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08
JavaScript trim 去除字符串空格的三種方法(附代碼詳解)
個(gè)人認(rèn)為最好的方法.采用的是正則表達(dá)式,這是最核心的原理.因?yàn)榭崭裼卸喾N形式。2010-05-05
Bootstrap基本組件學(xué)習(xí)筆記之下拉菜單(7)
這篇文章主要為大家詳細(xì)介紹了Bootstrap基本組件學(xué)習(xí)筆記之下拉菜單,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12
Bootstrap幻燈片輪播圖支持觸屏左右手勢(shì)滑動(dòng)的實(shí)現(xiàn)方法
最近在研究用bootstrap搭建網(wǎng)站,Bootstrap能自適應(yīng)pc端和手機(jī)端,并且移動(dòng)設(shè)備優(yōu)先,適合現(xiàn)如今移動(dòng)營(yíng)銷,大家用的設(shè)備基本是觸屏的了,能用滑動(dòng)交互在小屏幕上體驗(yàn)會(huì)更好,那么如何實(shí)現(xiàn)呢?下面小編給大家介紹下bootstrap 手勢(shì)滑動(dòng)輪播圖的實(shí)現(xiàn)方法2016-10-10
在瀏覽器測(cè)試JavaScript的方法小結(jié)
測(cè)試JavaScript代碼是一件很痛苦的事情,很多情況下都是寫(xiě)好代碼不斷刷新測(cè)試,其實(shí)chrome瀏覽器的console下就很方便,這里就為大家簡(jiǎn)單分享一下2023-03-03
JavaScript實(shí)現(xiàn)tab欄切換的效果
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)tab欄切換的效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09

