锘??xml version="1.0" encoding="utf-8" standalone="yes"?>亚洲精品社区,国产精品推荐精品,国产有码一区二区http://www.shnenglu.com/NicYun/鍩虹鐭ヨ瘑瀛︿範zh-cnWed, 17 Sep 2025 04:21:28 GMTWed, 17 Sep 2025 04:21:28 GMT60鏍戠姸鏁扮粍http://www.shnenglu.com/NicYun/archive/2009/03/13/76415.htmlNicYunNicYunFri, 13 Mar 2009 03:30:00 GMThttp://www.shnenglu.com/NicYun/archive/2009/03/13/76415.htmlhttp://www.shnenglu.com/NicYun/comments/76415.htmlhttp://www.shnenglu.com/NicYun/archive/2009/03/13/76415.html#Feedback0http://www.shnenglu.com/NicYun/comments/commentRss/76415.htmlhttp://www.shnenglu.com/NicYun/services/trackbacks/76415.htmlclass TreeArray
{
    
int c[1100000]; // element id must start at 1
    int size;
    
int lowbit(int x)
    {
        
return x & (-x);
    }
public:
    
void init(int s = N - 1)
    {
        size 
= s;
        memset(c,
0,size * sizeof(c[0]));
    }
    
int sum(int n) // 鍓峮涓暟鐨勫拰錛屽寘鎷琻
    {
        
int s = 0;
        
while (n > 0)
        {
            s 
+= c[n];
            n 
-= lowbit(n);
        }
        
return s;
    }
    
void plus(int p,int x) // add x to the element at position p
    {
        
while (p <= size)
        {
            c[p] 
+= x;
            p 
+= lowbit(p);
        }
    }
};



NicYun 2009-03-13 11:30 鍙戣〃璇勮
]]>
java 鍒嗘暟綾?/title><link>http://www.shnenglu.com/NicYun/archive/2009/03/08/75932.html</link><dc:creator>NicYun</dc:creator><author>NicYun</author><pubDate>Sun, 08 Mar 2009 13:02:00 GMT</pubDate><guid>http://www.shnenglu.com/NicYun/archive/2009/03/08/75932.html</guid><wfw:comment>http://www.shnenglu.com/NicYun/comments/75932.html</wfw:comment><comments>http://www.shnenglu.com/NicYun/archive/2009/03/08/75932.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.shnenglu.com/NicYun/comments/commentRss/75932.html</wfw:commentRss><trackback:ping>http://www.shnenglu.com/NicYun/services/trackbacks/75932.html</trackback:ping><description><![CDATA[<div style="border: 1px solid #cccccc; padding: 4px 5px 4px 4px; background-color: #eeeeee; font-size: 13px; width: 98%;"><!--<br><br>Code highlighting produced by Actipro CodeHighlighter (freeware)<br>http://www.CodeHighlighter.com/<br><br>--><span style="color: #0000ff;">class</span><span style="color: #000000;"> Fraction<br>{<br>    BigInteger up, down;<br>    </span><span style="color: #0000ff;">public</span><span style="color: #000000;"> Fraction (Fraction f)<br>    {<br>        </span><span style="color: #0000ff;">this</span><span style="color: #000000;">.up </span><span style="color: #000000;">=</span><span style="color: #000000;"> f.up;<br>        </span><span style="color: #0000ff;">this</span><span style="color: #000000;">.down </span><span style="color: #000000;">=</span><span style="color: #000000;"> f.down;<br>    }<br>    </span><span style="color: #0000ff;">public</span><span style="color: #000000;"> Fraction(String s)<br>    {<br>        </span><span style="color: #0000ff;">this</span><span style="color: #000000;">.up </span><span style="color: #000000;">=</span><span style="color: #000000;"> </span><span style="color: #0000ff;">new</span><span style="color: #000000;"> BigInteger(s);<br>        </span><span style="color: #0000ff;">this</span><span style="color: #000000;">.down </span><span style="color: #000000;">=</span><span style="color: #000000;"> </span><span style="color: #0000ff;">new</span><span style="color: #000000;"> BigInteger(</span><span style="color: #000000;">"</span><span style="color: #000000;">1</span><span style="color: #000000;">"</span><span style="color: #000000;">);<br>    }<br>    </span><span style="color: #0000ff;">public</span><span style="color: #000000;"> Fraction(BigInteger a, BigInteger b)<br>    {<br>        </span><span style="color: #0000ff;">this</span><span style="color: #000000;">.up </span><span style="color: #000000;">=</span><span style="color: #000000;"> a;<br>        </span><span style="color: #0000ff;">this</span><span style="color: #000000;">.down </span><span style="color: #000000;">=</span><span style="color: #000000;"> b;<br>    }<br>    </span><span style="color: #0000ff;">public</span><span style="color: #000000;"> BigInteger getUp()<br>    {<br>        </span><span style="color: #0000ff;">return</span><span style="color: #000000;"> </span><span style="color: #0000ff;">this</span><span style="color: #000000;">.up;<br>    }<br>    </span><span style="color: #0000ff;">public</span><span style="color: #000000;"> BigInteger getDown()<br>    {<br>        </span><span style="color: #0000ff;">return</span><span style="color: #000000;"> </span><span style="color: #0000ff;">this</span><span style="color: #000000;">.down;<br>    }<br>    </span><span style="color: #0000ff;">public</span><span style="color: #000000;"> Fraction subtract(Fraction f)<br>    {<br>        BigInteger save1 </span><span style="color: #000000;">=</span><span style="color: #000000;"> </span><span style="color: #0000ff;">this</span><span style="color: #000000;">.up.multiply (f.down);<br>        BigInteger save2 </span><span style="color: #000000;">=</span><span style="color: #000000;"> f.up.multiply(</span><span style="color: #0000ff;">this</span><span style="color: #000000;">.down);<br>        Fraction tmp </span><span style="color: #000000;">=</span><span style="color: #000000;"> </span><span style="color: #0000ff;">new</span><span style="color: #000000;"> Fraction(save1.subtract (save2), f.down .multiply ( </span><span style="color: #0000ff;">this</span><span style="color: #000000;">.down));<br>        </span><span style="color: #0000ff;">return</span><span style="color: #000000;"> simplex(tmp);<br>    }<br>    </span><span style="color: #0000ff;">public</span><span style="color: #000000;"> Fraction add(Fraction f)<br>    {<br>        Fraction tmp </span><span style="color: #000000;">=</span><span style="color: #000000;"> </span><span style="color: #0000ff;">new</span><span style="color: #000000;"> Fraction (</span><span style="color: #000000;">"</span><span style="color: #000000;">0</span><span style="color: #000000;">"</span><span style="color: #000000;">);<br>        tmp </span><span style="color: #000000;">=</span><span style="color: #000000;"> tmp.subtract(f);<br>        Fraction ans </span><span style="color: #000000;">=</span><span style="color: #000000;"> </span><span style="color: #0000ff;">new</span><span style="color: #000000;"> Fraction (</span><span style="color: #0000ff;">this</span><span style="color: #000000;">.subtract(tmp));<br>        </span><span style="color: #0000ff;">return</span><span style="color: #000000;"> ans;<br>    }<br>    </span><span style="color: #0000ff;">public</span><span style="color: #000000;"> Fraction multiply(Fraction f)<br>    {<br>        Fraction tmp;<br>        tmp </span><span style="color: #000000;">=</span><span style="color: #000000;"> </span><span style="color: #0000ff;">new</span><span style="color: #000000;"> Fraction(</span><span style="color: #0000ff;">this</span><span style="color: #000000;">.up.multiply (f.up), </span><span style="color: #0000ff;">this</span><span style="color: #000000;">.down.multiply (f.down));<br>        </span><span style="color: #0000ff;">if</span><span style="color: #000000;"> (tmp.down.compareTo(</span><span style="color: #0000ff;">new</span><span style="color: #000000;"> BigInteger(</span><span style="color: #000000;">"</span><span style="color: #000000;">0</span><span style="color: #000000;">"</span><span style="color: #000000;">)) </span><span style="color: #000000;">==</span><span style="color: #000000;"> </span><span style="color: #000000;">-</span><span style="color: #000000;">1</span><span style="color: #000000;">)<br>        {<br>            tmp.down </span><span style="color: #000000;">=</span><span style="color: #000000;"> tmp.down.multiply (</span><span style="color: #0000ff;">new</span><span style="color: #000000;"> BigInteger(</span><span style="color: #000000;">"</span><span style="color: #000000;">-1</span><span style="color: #000000;">"</span><span style="color: #000000;">));<br>            tmp.up </span><span style="color: #000000;">=</span><span style="color: #000000;"> tmp.up.multiply (</span><span style="color: #0000ff;">new</span><span style="color: #000000;"> BigInteger(</span><span style="color: #000000;">"</span><span style="color: #000000;">-1</span><span style="color: #000000;">"</span><span style="color: #000000;">));<br>        }<br>        </span><span style="color: #0000ff;">return</span><span style="color: #000000;"> simplex(tmp);<br>    }<br>    </span><span style="color: #0000ff;">public</span><span style="color: #000000;"> Fraction divide(Fraction f)<br>    {<br>        Fraction tmp </span><span style="color: #000000;">=</span><span style="color: #000000;"> </span><span style="color: #0000ff;">null</span><span style="color: #000000;">;<br>        tmp </span><span style="color: #000000;">=</span><span style="color: #000000;"> </span><span style="color: #0000ff;">new</span><span style="color: #000000;"> Fraction(</span><span style="color: #0000ff;">this</span><span style="color: #000000;">.up.multiply (f.down), </span><span style="color: #0000ff;">this</span><span style="color: #000000;">.down.multiply (f.up));<br>        </span><span style="color: #0000ff;">if</span><span style="color: #000000;"> (tmp.down.compareTo(</span><span style="color: #0000ff;">new</span><span style="color: #000000;"> BigInteger(</span><span style="color: #000000;">"</span><span style="color: #000000;">0</span><span style="color: #000000;">"</span><span style="color: #000000;">)) </span><span style="color: #000000;">==</span><span style="color: #000000;"> </span><span style="color: #000000;">-</span><span style="color: #000000;">1</span><span style="color: #000000;">)<br>        {<br>            tmp.down </span><span style="color: #000000;">=</span><span style="color: #000000;"> tmp.down.multiply (</span><span style="color: #0000ff;">new</span><span style="color: #000000;"> BigInteger(</span><span style="color: #000000;">"</span><span style="color: #000000;">-1</span><span style="color: #000000;">"</span><span style="color: #000000;">));<br>            tmp.up </span><span style="color: #000000;">=</span><span style="color: #000000;"> tmp.up.multiply (</span><span style="color: #0000ff;">new</span><span style="color: #000000;"> BigInteger(</span><span style="color: #000000;">"</span><span style="color: #000000;">-1</span><span style="color: #000000;">"</span><span style="color: #000000;">));<br>        }<br>        </span><span style="color: #0000ff;">return</span><span style="color: #000000;"> simplex(tmp);<br>    }<br>    BigInteger gcd(BigInteger a, BigInteger b)<br>    {<br>        </span><span style="color: #0000ff;">if</span><span style="color: #000000;"> (b.compareTo(</span><span style="color: #0000ff;">new</span><span style="color: #000000;"> BigInteger(</span><span style="color: #000000;">"</span><span style="color: #000000;">0</span><span style="color: #000000;">"</span><span style="color: #000000;">)) </span><span style="color: #000000;">==</span><span style="color: #000000;"> </span><span style="color: #000000;">0</span><span style="color: #000000;">)<br>            </span><span style="color: #0000ff;">return</span><span style="color: #000000;"> a;<br>        </span><span style="color: #0000ff;">return</span><span style="color: #000000;"> gcd(b, a.remainder (b));<br>    }<br>    Fraction simplex(Fraction f)<br>    {<br>        BigInteger tmp </span><span style="color: #000000;">=</span><span style="color: #000000;"> gcd(f.up.abs(), f.down.abs ());<br>        f.up </span><span style="color: #000000;">=</span><span style="color: #000000;"> f.up.divide (tmp);<br>        f.down </span><span style="color: #000000;">=</span><span style="color: #000000;"> f.down.divide (tmp);<br>        </span><span style="color: #0000ff;">return</span><span style="color: #000000;"> f;<br>    }<br>    </span><span style="color: #0000ff;">void</span><span style="color: #000000;"> print()<br>    {<br>        BigInteger a, b, c;<br>        a </span><span style="color: #000000;">=</span><span style="color: #000000;"> </span><span style="color: #0000ff;">this</span><span style="color: #000000;">.getUp ();<br>        b </span><span style="color: #000000;">=</span><span style="color: #000000;"> </span><span style="color: #0000ff;">this</span><span style="color: #000000;">.getDown();<br>        c </span><span style="color: #000000;">=</span><span style="color: #000000;"> gcd(a.abs(), b.abs());<br>        a </span><span style="color: #000000;">=</span><span style="color: #000000;"> a.divide (c);<br>        b </span><span style="color: #000000;">=</span><span style="color: #000000;"> b.divide (c);<br>        </span><span style="color: #0000ff;">if</span><span style="color: #000000;"> (b.compareTo (</span><span style="color: #0000ff;">new</span><span style="color: #000000;"> BigInteger(</span><span style="color: #000000;">"</span><span style="color: #000000;">1</span><span style="color: #000000;">"</span><span style="color: #000000;">)) </span><span style="color: #000000;">==</span><span style="color: #000000;"> </span><span style="color: #000000;">0</span><span style="color: #000000;">)<br>            System.out.println(a);<br>        </span><span style="color: #0000ff;">else</span><span style="color: #000000;"><br>            System.out.println (a </span><span style="color: #000000;">+</span><span style="color: #000000;"> </span><span style="color: #000000;">"</span><span style="color: #000000;">/</span><span style="color: #000000;">"</span><span style="color: #000000;"> </span><span style="color: #000000;">+</span><span style="color: #000000;"> b);<br>    }<br>}</span></div> <br><img src ="http://www.shnenglu.com/NicYun/aggbug/75932.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.shnenglu.com/NicYun/" target="_blank">NicYun</a> 2009-03-08 21:02 <a href="http://www.shnenglu.com/NicYun/archive/2009/03/08/75932.html#Feedback" target="_blank" style="text-decoration:none;">鍙戣〃璇勮</a></div>]]></description></item><item><title>綰挎鏍?/title><link>http://www.shnenglu.com/NicYun/archive/2008/08/05/58037.html</link><dc:creator>NicYun</dc:creator><author>NicYun</author><pubDate>Tue, 05 Aug 2008 01:24:00 GMT</pubDate><guid>http://www.shnenglu.com/NicYun/archive/2008/08/05/58037.html</guid><wfw:comment>http://www.shnenglu.com/NicYun/comments/58037.html</wfw:comment><comments>http://www.shnenglu.com/NicYun/archive/2008/08/05/58037.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.shnenglu.com/NicYun/comments/commentRss/58037.html</wfw:commentRss><trackback:ping>http://www.shnenglu.com/NicYun/services/trackbacks/58037.html</trackback:ping><description><![CDATA[<div style="border: 1px solid #cccccc; padding: 4px 5px 4px 4px; font-size: 13px; width: 98%; background-color: #eeeeee;"><span style="color: #000000;">#include </span><span style="color: #000000;"><</span><span style="color: #000000;">iostream</span><span style="color: #000000;">></span><span style="color: #000000;"><br>#include </span><span style="color: #000000;"><</span><span style="color: #0000ff;">string</span><span style="color: #000000;">></span><span style="color: #000000;"><br>#include </span><span style="color: #000000;"><</span><span style="color: #000000;">algorithm</span><span style="color: #000000;">></span><span style="color: #000000;"><br></span><span style="color: #0000ff;">using</span><span style="color: #000000;"> </span><span style="color: #0000ff;">namespace</span><span style="color: #000000;"> std;<br><br></span><span style="color: #0000ff;">const</span><span style="color: #000000;"> </span><span style="color: #0000ff;">int</span><span style="color: #000000;"> SIZE </span><span style="color: #000000;">=</span><span style="color: #000000;"> </span><span style="color: #000000;">10010</span><span style="color: #000000;">;<br><br></span><span style="color: #0000ff;">struct</span><span style="color: #000000;"> node </span><span style="color: #008000;">//</span><span style="color: #008000;"> the node of line tree</span><span style="color: #008000;"><br></span><span style="color: #000000;">{<br>    </span><span style="color: #0000ff;">int</span><span style="color: #000000;"> i,j; </span><span style="color: #008000;">//</span><span style="color: #008000;"> 鍖洪棿鑼冨洿</span><span style="color: #008000;"><br></span><span style="color: #000000;">    node </span><span style="color: #000000;">*</span><span style="color: #000000;"> lson;<br>    node </span><span style="color: #000000;">*</span><span style="color: #000000;"> rson;<br>    </span><span style="color: #0000ff;">int</span><span style="color: #000000;"> count; </span><span style="color: #008000;">//</span><span style="color: #008000;"> 綰挎瑕嗙洊鏉℃暟</span><span style="color: #008000;"><br></span><span style="color: #000000;">    </span><span style="color: #0000ff;">int</span><span style="color: #000000;"> m; </span><span style="color: #008000;">//</span><span style="color: #008000;"> 嫻嬪害</span><span style="color: #008000;"><br></span><span style="color: #000000;">    </span><span style="color: #0000ff;">int</span><span style="color: #000000;"> line; </span><span style="color: #008000;">//</span><span style="color: #008000;"> 榪炵畫孌墊暟</span><span style="color: #008000;"><br></span><span style="color: #000000;">    </span><span style="color: #0000ff;">int</span><span style="color: #000000;"> lbd,rbd; </span><span style="color: #008000;">//</span><span style="color: #008000;"> 鐢ㄦ潵璁$畻榪炵畫孌墊暟</span><span style="color: #008000;"><br></span><span style="color: #000000;">    node(</span><span style="color: #0000ff;">int</span><span style="color: #000000;"> l,</span><span style="color: #0000ff;">int</span><span style="color: #000000;"> r)<br>    {<br>        i </span><span style="color: #000000;">=</span><span style="color: #000000;"> l,j </span><span style="color: #000000;">=</span><span style="color: #000000;"> r;<br>        count </span><span style="color: #000000;">=</span><span style="color: #000000;"> m </span><span style="color: #000000;">=</span><span style="color: #000000;"> line </span><span style="color: #000000;">=</span><span style="color: #000000;"> lbd </span><span style="color: #000000;">=</span><span style="color: #000000;"> rbd </span><span style="color: #000000;">=</span><span style="color: #000000;"> </span><span style="color: #000000;">0</span><span style="color: #000000;">;<br>        lson </span><span style="color: #000000;">=</span><span style="color: #000000;"> rson </span><span style="color: #000000;">=</span><span style="color: #000000;"> NULL;<br>    }<br>};<br></span><span style="color: #0000ff;">class</span><span style="color: #000000;"> LineTree<br>{<br>    node </span><span style="color: #000000;">*</span><span style="color: #000000;"> head;<br>    </span><span style="color: #008000;">/*</span><span style="color: #008000;"> 浠ヤ笅鍑芥暟鍐呴儴浣跨敤,鍙笉鐢ㄨ冭檻 </span><span style="color: #008000;">*/</span><span style="color: #000000;"><br>    </span><span style="color: #0000ff;">void</span><span style="color: #000000;"> init(node </span><span style="color: #000000;">*</span><span style="color: #000000;"> pnode </span><span style="color: #000000;">=</span><span style="color: #000000;"> NULL)<br>    {<br>        head </span><span style="color: #000000;">=</span><span style="color: #000000;"> pnode;<br>    }<br>    </span><span style="color: #0000ff;">void</span><span style="color: #000000;"> updateM()<br>    {<br>        </span><span style="color: #0000ff;">if</span><span style="color: #000000;"> (head</span><span style="color: #000000;">-></span><span style="color: #000000;">count </span><span style="color: #000000;">></span><span style="color: #000000;"> </span><span style="color: #000000;">0</span><span style="color: #000000;">) </span><span style="color: #008000;">//</span><span style="color: #008000;"> 琚鐩栨弧</span><span style="color: #008000;"><br></span><span style="color: #000000;">            head</span><span style="color: #000000;">-></span><span style="color: #000000;">m </span><span style="color: #000000;">=</span><span style="color: #000000;"> head</span><span style="color: #000000;">-></span><span style="color: #000000;">j </span><span style="color: #000000;">-</span><span style="color: #000000;"> head</span><span style="color: #000000;">-></span><span style="color: #000000;">i;<br>        </span><span style="color: #0000ff;">else</span><span style="color: #000000;"> </span><span style="color: #0000ff;">if</span><span style="color: #000000;"> (head</span><span style="color: #000000;">-></span><span style="color: #000000;">j </span><span style="color: #000000;">-</span><span style="color: #000000;"> head</span><span style="color: #000000;">-></span><span style="color: #000000;">i </span><span style="color: #000000;">==</span><span style="color: #000000;"> </span><span style="color: #000000;">1</span><span style="color: #000000;">) </span><span style="color: #008000;">//</span><span style="color: #008000;"> 璇ヨ妭鐐逛負鍙惰妭鐐?/span><span style="color: #008000;"><br></span><span style="color: #000000;">            head</span><span style="color: #000000;">-></span><span style="color: #000000;">m </span><span style="color: #000000;">=</span><span style="color: #000000;"> </span><span style="color: #000000;">0</span><span style="color: #000000;">;<br>        </span><span style="color: #0000ff;">else</span><span style="color: #000000;">    </span><span style="color: #008000;">//</span><span style="color: #008000;"> 鍏朵粬鍐呴儴鑺傜偣鐨勬儏鍐?/span><span style="color: #008000;"><br></span><span style="color: #000000;">            head</span><span style="color: #000000;">-></span><span style="color: #000000;">m </span><span style="color: #000000;">=</span><span style="color: #000000;"> (head</span><span style="color: #000000;">-></span><span style="color: #000000;">lson)</span><span style="color: #000000;">-></span><span style="color: #000000;">m </span><span style="color: #000000;">+</span><span style="color: #000000;"> (head</span><span style="color: #000000;">-></span><span style="color: #000000;">rson)</span><span style="color: #000000;">-></span><span style="color: #000000;">m;<br>    }<br>    </span><span style="color: #0000ff;">void</span><span style="color: #000000;"> updateLine()<br>    {<br>        </span><span style="color: #0000ff;">if</span><span style="color: #000000;"> (head</span><span style="color: #000000;">-></span><span style="color: #000000;">count </span><span style="color: #000000;">></span><span style="color: #000000;"> </span><span style="color: #000000;">0</span><span style="color: #000000;">)<br>            head</span><span style="color: #000000;">-></span><span style="color: #000000;">lbd </span><span style="color: #000000;">=</span><span style="color: #000000;"> head</span><span style="color: #000000;">-></span><span style="color: #000000;">rbd </span><span style="color: #000000;">=</span><span style="color: #000000;"> head</span><span style="color: #000000;">-></span><span style="color: #000000;">line </span><span style="color: #000000;">=</span><span style="color: #000000;"> </span><span style="color: #000000;">1</span><span style="color: #000000;">;<br>        </span><span style="color: #0000ff;">else</span><span style="color: #000000;"> </span><span style="color: #0000ff;">if</span><span style="color: #000000;"> (head</span><span style="color: #000000;">-></span><span style="color: #000000;">j </span><span style="color: #000000;">-</span><span style="color: #000000;"> head</span><span style="color: #000000;">-></span><span style="color: #000000;">i </span><span style="color: #000000;">==</span><span style="color: #000000;"> </span><span style="color: #000000;">1</span><span style="color: #000000;">)<br>            head</span><span style="color: #000000;">-></span><span style="color: #000000;">lbd </span><span style="color: #000000;">=</span><span style="color: #000000;"> head</span><span style="color: #000000;">-></span><span style="color: #000000;">rbd </span><span style="color: #000000;">=</span><span style="color: #000000;"> head</span><span style="color: #000000;">-></span><span style="color: #000000;">line </span><span style="color: #000000;">=</span><span style="color: #000000;"> </span><span style="color: #000000;">0</span><span style="color: #000000;">;<br>        </span><span style="color: #0000ff;">else</span><span style="color: #000000;"><br>        {<br>            head</span><span style="color: #000000;">-></span><span style="color: #000000;">lbd </span><span style="color: #000000;">=</span><span style="color: #000000;"> (head</span><span style="color: #000000;">-></span><span style="color: #000000;">lson)</span><span style="color: #000000;">-></span><span style="color: #000000;">lbd;<br>            head</span><span style="color: #000000;">-></span><span style="color: #000000;">rbd </span><span style="color: #000000;">=</span><span style="color: #000000;"> (head</span><span style="color: #000000;">-></span><span style="color: #000000;">rson)</span><span style="color: #000000;">-></span><span style="color: #000000;">rbd;<br>            head</span><span style="color: #000000;">-></span><span style="color: #000000;">line </span><span style="color: #000000;">=</span><span style="color: #000000;"> (head</span><span style="color: #000000;">-></span><span style="color: #000000;">lson)</span><span style="color: #000000;">-></span><span style="color: #000000;">line </span><span style="color: #000000;">+</span><span style="color: #000000;"> (head</span><span style="color: #000000;">-></span><span style="color: #000000;">rson)</span><span style="color: #000000;">-></span><span style="color: #000000;">line </span><span style="color: #000000;">-</span><span style="color: #000000;"> (head</span><span style="color: #000000;">-></span><span style="color: #000000;">lson)</span><span style="color: #000000;">-></span><span style="color: #000000;">rbd </span><span style="color: #000000;">*</span><span style="color: #000000;"> (head</span><span style="color: #000000;">-></span><span style="color: #000000;">rson)</span><span style="color: #000000;">-></span><span style="color: #000000;">lbd;<br>        }<br>    }<br></span><span style="color: #0000ff;">public</span><span style="color: #000000;">:<br>    LineTree();<br>    </span><span style="color: #0000ff;">void</span><span style="color: #000000;"> clear(); </span><span style="color: #008000;">//</span><span style="color: #008000;"> 娓呯┖綰挎鏁?</span><span style="color: #008000;"><br></span><span style="color: #000000;">    </span><span style="color: #0000ff;">void</span><span style="color: #000000;"> build(</span><span style="color: #0000ff;">int</span><span style="color: #000000;"> l,</span><span style="color: #0000ff;">int</span><span style="color: #000000;"> r); </span><span style="color: #008000;">//</span><span style="color: #008000;"> 寤虹珛綰挎鏍?鍖洪棿[l,r];</span><span style="color: #008000;"><br></span><span style="color: #000000;">    </span><span style="color: #0000ff;">void</span><span style="color: #000000;"> insert(</span><span style="color: #0000ff;">int</span><span style="color: #000000;"> l,</span><span style="color: #0000ff;">int</span><span style="color: #000000;"> r); </span><span style="color: #008000;">//</span><span style="color: #008000;"> 鎻掑叆涓鏉$嚎孌?</span><span style="color: #008000;"><br></span><span style="color: #000000;">    </span><span style="color: #0000ff;">void</span><span style="color: #000000;"> del(</span><span style="color: #0000ff;">int</span><span style="color: #000000;"> l,</span><span style="color: #0000ff;">int</span><span style="color: #000000;"> r); </span><span style="color: #008000;">//</span><span style="color: #008000;"> 鍒犻櫎涓鏉$嚎孌?</span><span style="color: #008000;"><br></span><span style="color: #000000;">    </span><span style="color: #0000ff;">int</span><span style="color: #000000;"> GetM(); </span><span style="color: #008000;">//</span><span style="color: #008000;"> 嫻嬪害;</span><span style="color: #008000;"><br></span><span style="color: #000000;">    </span><span style="color: #0000ff;">int</span><span style="color: #000000;"> GetLine(); </span><span style="color: #008000;">//</span><span style="color: #008000;"> 榪炵畫孌墊暟;</span><span style="color: #008000;"><br></span><span style="color: #000000;">    </span><span style="color: #0000ff;">int</span><span style="color: #000000;"> GetCov(); </span><span style="color: #008000;">//</span><span style="color: #008000;"> 瑕嗙洊綰挎鏁?</span><span style="color: #008000;"><br></span><span style="color: #000000;">    </span><span style="color: #000000;">~</span><span style="color: #000000;">LineTree();<br>};<br>LineTree::LineTree()<br>{<br>    head </span><span style="color: #000000;">=</span><span style="color: #000000;"> NULL;<br>}<br></span><span style="color: #0000ff;">void</span><span style="color: #000000;"> LineTree::clear() </span><span style="color: #008000;">//</span><span style="color: #008000;"> 娓呯┖綰挎鏁?/span><span style="color: #008000;"><br></span><span style="color: #000000;">{<br>    </span><span style="color: #0000ff;">if</span><span style="color: #000000;"> (head </span><span style="color: #000000;">==</span><span style="color: #000000;"> NULL)<br>        </span><span style="color: #0000ff;">return</span><span style="color: #000000;">;<br>    LineTree temp;<br>    temp.init(head</span><span style="color: #000000;">-></span><span style="color: #000000;">lson);<br>    temp.clear();<br>    temp.init(head</span><span style="color: #000000;">-></span><span style="color: #000000;">rson);<br>    temp.clear();<br>    delete head;<br>    head </span><span style="color: #000000;">=</span><span style="color: #000000;"> NULL;<br>}<br></span><span style="color: #0000ff;">void</span><span style="color: #000000;"> LineTree::build(</span><span style="color: #0000ff;">int</span><span style="color: #000000;"> l,</span><span style="color: #0000ff;">int</span><span style="color: #000000;"> r) </span><span style="color: #008000;">//</span><span style="color: #008000;"> 寤虹珛綰挎鏍?鍖洪棿[l,r]</span><span style="color: #008000;"><br></span><span style="color: #000000;">{<br>    head </span><span style="color: #000000;">=</span><span style="color: #000000;"> </span><span style="color: #0000ff;">new</span><span style="color: #000000;"> node(l,r);<br>    </span><span style="color: #0000ff;">if</span><span style="color: #000000;"> (r </span><span style="color: #000000;">-</span><span style="color: #000000;"> l </span><span style="color: #000000;">></span><span style="color: #000000;"> </span><span style="color: #000000;">1</span><span style="color: #000000;">)<br>    {<br>        </span><span style="color: #0000ff;">int</span><span style="color: #000000;"> k </span><span style="color: #000000;">=</span><span style="color: #000000;"> (l </span><span style="color: #000000;">+</span><span style="color: #000000;"> r) </span><span style="color: #000000;">/</span><span style="color: #000000;"> </span><span style="color: #000000;">2</span><span style="color: #000000;">;<br>        LineTree temp;<br>        temp.build(l,k);<br>        head</span><span style="color: #000000;">-></span><span style="color: #000000;">lson </span><span style="color: #000000;">=</span><span style="color: #000000;"> temp.head;<br>        temp.init();<br>        temp.build(k,r);<br>        head</span><span style="color: #000000;">-></span><span style="color: #000000;">rson </span><span style="color: #000000;">=</span><span style="color: #000000;"> temp.head;<br>    }<br>}<br></span><span style="color: #0000ff;">void</span><span style="color: #000000;"> LineTree::insert(</span><span style="color: #0000ff;">int</span><span style="color: #000000;"> l,</span><span style="color: #0000ff;">int</span><span style="color: #000000;"> r) </span><span style="color: #008000;">//</span><span style="color: #008000;"> 鎻掑叆涓鏉$嚎孌?/span><span style="color: #008000;"><br></span><span style="color: #000000;">{<br>    </span><span style="color: #0000ff;">if</span><span style="color: #000000;"> (l </span><span style="color: #000000;"><=</span><span style="color: #000000;"> head</span><span style="color: #000000;">-></span><span style="color: #000000;">i </span><span style="color: #000000;">&&</span><span style="color: #000000;"> r </span><span style="color: #000000;">>=</span><span style="color: #000000;"> head</span><span style="color: #000000;">-></span><span style="color: #000000;">j)<br>        (head</span><span style="color: #000000;">-></span><span style="color: #000000;">count)</span><span style="color: #000000;">++</span><span style="color: #000000;">;<br>    </span><span style="color: #0000ff;">else</span><span style="color: #000000;"><br>    {<br>        LineTree temp;<br>        </span><span style="color: #0000ff;">if</span><span style="color: #000000;"> (l </span><span style="color: #000000;"><</span><span style="color: #000000;"> (head</span><span style="color: #000000;">-></span><span style="color: #000000;">i</span><span style="color: #000000;">+</span><span style="color: #000000;">head</span><span style="color: #000000;">-></span><span style="color: #000000;">j)</span><span style="color: #000000;">/</span><span style="color: #000000;">2</span><span style="color: #000000;">)<br>        {<br>            temp.init(head</span><span style="color: #000000;">-></span><span style="color: #000000;">lson);<br>            temp.insert(l,r);<br>        }<br>        </span><span style="color: #0000ff;">if</span><span style="color: #000000;"> (r </span><span style="color: #000000;">></span><span style="color: #000000;"> (head</span><span style="color: #000000;">-></span><span style="color: #000000;">i</span><span style="color: #000000;">+</span><span style="color: #000000;">head</span><span style="color: #000000;">-></span><span style="color: #000000;">j)</span><span style="color: #000000;">/</span><span style="color: #000000;">2</span><span style="color: #000000;">)<br>        {<br>            temp.init(head</span><span style="color: #000000;">-></span><span style="color: #000000;">rson);<br>            temp.insert(l,r);<br>        }<br>    }<br>    updateM();<br>    updateLine();<br>}<br></span><span style="color: #0000ff;">void</span><span style="color: #000000;"> LineTree::del(</span><span style="color: #0000ff;">int</span><span style="color: #000000;"> l,</span><span style="color: #0000ff;">int</span><span style="color: #000000;"> r) </span><span style="color: #008000;">//</span><span style="color: #008000;"> 鍒犻櫎涓鏉$嚎孌?/span><span style="color: #008000;"><br></span><span style="color: #000000;">{<br>    </span><span style="color: #0000ff;">if</span><span style="color: #000000;"> (l </span><span style="color: #000000;"><=</span><span style="color: #000000;"> head</span><span style="color: #000000;">-></span><span style="color: #000000;">i </span><span style="color: #000000;">&&</span><span style="color: #000000;"> head</span><span style="color: #000000;">-></span><span style="color: #000000;">j </span><span style="color: #000000;"><=</span><span style="color: #000000;"> r)<br>        (head</span><span style="color: #000000;">-></span><span style="color: #000000;">count)</span><span style="color: #000000;">--</span><span style="color: #000000;">;<br>    </span><span style="color: #0000ff;">else</span><span style="color: #000000;"><br>    {<br>        LineTree temp;<br>        </span><span style="color: #0000ff;">if</span><span style="color: #000000;"> (l </span><span style="color: #000000;"><</span><span style="color: #000000;"> (head</span><span style="color: #000000;">-></span><span style="color: #000000;">i</span><span style="color: #000000;">+</span><span style="color: #000000;">head</span><span style="color: #000000;">-></span><span style="color: #000000;">j)</span><span style="color: #000000;">/</span><span style="color: #000000;">2</span><span style="color: #000000;">)<br>        {<br>            temp.init(head</span><span style="color: #000000;">-></span><span style="color: #000000;">lson);<br>            temp.del(l,r);<br>        }<br>        </span><span style="color: #0000ff;">if</span><span style="color: #000000;"> (r </span><span style="color: #000000;">></span><span style="color: #000000;"> (head</span><span style="color: #000000;">-></span><span style="color: #000000;">i</span><span style="color: #000000;">+</span><span style="color: #000000;">head</span><span style="color: #000000;">-></span><span style="color: #000000;">j)</span><span style="color: #000000;">/</span><span style="color: #000000;">2</span><span style="color: #000000;">)<br>        {<br>            temp.init(head</span><span style="color: #000000;">-></span><span style="color: #000000;">rson);<br>            temp.del(l,r);<br>        }<br>    }<br>    updateM();<br>    updateLine();<br>}<br></span><span style="color: #0000ff;">int</span><span style="color: #000000;"> LineTree::GetM() </span><span style="color: #008000;">//</span><span style="color: #008000;"> 嫻嬪害</span><span style="color: #008000;"><br></span><span style="color: #000000;">{<br>    </span><span style="color: #0000ff;">return</span><span style="color: #000000;"> head</span><span style="color: #000000;">-></span><span style="color: #000000;">m;<br>}<br></span><span style="color: #0000ff;">int</span><span style="color: #000000;"> LineTree::GetLine() </span><span style="color: #008000;">//</span><span style="color: #008000;"> 榪炵畫孌墊暟</span><span style="color: #008000;"><br></span><span style="color: #000000;">{<br>    </span><span style="color: #0000ff;">return</span><span style="color: #000000;"> head</span><span style="color: #000000;">-></span><span style="color: #000000;">line;<br>}<br></span><span style="color: #0000ff;">int</span><span style="color: #000000;"> LineTree::GetCov() </span><span style="color: #008000;">//</span><span style="color: #008000;"> 瑕嗙洊綰挎鏁?/span><span style="color: #008000;"><br></span><span style="color: #000000;">{<br>    </span><span style="color: #0000ff;">return</span><span style="color: #000000;"> head</span><span style="color: #000000;">-></span><span style="color: #000000;">count;<br>}<br>LineTree::</span><span style="color: #000000;">~</span><span style="color: #000000;">LineTree()<br>{<br>    </span><span style="color: #0000ff;">this</span><span style="color: #000000;">-></span><span style="color: #000000;">clear();<br>}<br><br></span></div><img src ="http://www.shnenglu.com/NicYun/aggbug/58037.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.shnenglu.com/NicYun/" target="_blank">NicYun</a> 2008-08-05 09:24 <a href="http://www.shnenglu.com/NicYun/archive/2008/08/05/58037.html#Feedback" target="_blank" style="text-decoration:none;">鍙戣〃璇勮</a></div>]]></description></item><item><title>鏈灝忓爢鍜屾渶澶у爢http://www.shnenglu.com/NicYun/archive/2008/08/04/57934.htmlNicYunNicYunMon, 04 Aug 2008 02:29:00 GMThttp://www.shnenglu.com/NicYun/archive/2008/08/04/57934.htmlhttp://www.shnenglu.com/NicYun/comments/57934.htmlhttp://www.shnenglu.com/NicYun/archive/2008/08/04/57934.html#Feedback0http://www.shnenglu.com/NicYun/comments/commentRss/57934.htmlhttp://www.shnenglu.com/NicYun/services/trackbacks/57934.html#include <iostream>
#include 
<string>
#include 
<stdio.h>
using namespace std;

#define SIZE  500000

void swap(int &a,int &b)
{
    
int temp = a;
    a 
= b;
    b 
= temp;
}

class Heap
{
    
int size;
    
int heap[SIZE];
public:
    
virtual bool cmp(int a,int b) = 0;
private:
    inline 
int fathter(int p)
    {
        
return p / 2;
    }
    inline 
int LeftSon(int p)
    {
        
int son = 2 * p;
        
if (son > size)
            
return 0;
        
return son;
    }
    inline 
int RightSon(int p)
    {
        
int son = 2 * p + 1;
        
if (son > size)
            
return 0;
        
return son;
    }
    
int ShiftUp(int p)
    {
        
if (p == 1)
            
return p;
        
if (cmp(heap[p],heap[fathter(p)]))
        {
            swap(heap[p],heap[fathter(p)]);
            
return fathter(p);
        }
        
return p;
    }
    
int ShiftDown(int p)
    {
        
int lagest = p;

        
if ((LeftSon(p)) && (cmp(heap[LeftSon(p)],heap[lagest])))
            lagest 
= LeftSon(p);
        
if ((RightSon(p)) && (cmp(heap[RightSon(p)],heap[lagest])))
            lagest 
= RightSon(p);
        
if (lagest != p)
            swap(heap[lagest],heap[p]);
        
return lagest;
    }
public:
    Heap() { size 
= 0; }
    
int insert(int n);
    
void del(int p);
    
void DelHead();
    
int head();
    
void init();
    
bool IsEempty();
};
int Heap::insert(int n)
{
    size
++;
    heap[size] 
= n;
    
int where = size;
    
int p;
    
while (((p = ShiftUp(where)) != where))
    {
        where 
= p;
        
continue;
    }
    
return where;
}
void Heap::del(int p)
{
    heap[p] 
= heap[size];
    size
--;
    
int where;
    
while (((where = ShiftDown(p)) != p))
    {
        p 
= where;
        
continue;
    }
}
void Heap::DelHead()
{
    del(
1);
}
int Heap::head()
{
    
if (size == 0)
        
return -1;
    
return heap[1];
}
void Heap::init()
{
    size 
= 0;
}
bool Heap::IsEempty()
{
    
if (size == 0)
        
return 1;
    
else
        
return 0;
}

class MaxHeap : public Heap
{
    
bool cmp(int a,int b)
    {
        
return a > b;
    }
};

class MinHeap : public Heap
{
    
bool cmp(int a,int b)
    {
        
return a < b;
    }
};

int main()
{
    
return 0;
}


NicYun 2008-08-04 10:29 鍙戣〃璇勮
]]>
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲美女电影在线| 久久夜色撩人精品| 99成人在线| 欧美日韩高清不卡| 一区二区高清在线| 亚洲视频欧美视频| 国产欧美日韩精品a在线观看| 亚洲在线播放电影| 先锋资源久久| 在线观看欧美日本| 日韩午夜黄色| 国产伊人精品| 亚洲激情第一区| 欧美日韩精品中文字幕| 欧美在线视频播放| 另类酷文…触手系列精品集v1小说| 亚洲精品一区二区网址| 亚洲视频综合| 亚洲第一在线| 亚洲一二三区精品| 亚洲国产毛片完整版| 日韩一区二区电影网| 国内揄拍国内精品少妇国语| 亚洲电影下载| 国产视频一区欧美| 亚洲激情视频网站| 国产亚洲激情在线| 亚洲国产欧美在线| 国产一区二区黄色| 99精品福利视频| 在线不卡亚洲| 亚洲影院在线| 亚洲免费高清视频| 久久riav二区三区| 亚洲一区二区三区在线| 男人天堂欧美日韩| 久久精品一区二区| 欧美日韩极品在线观看一区| 久久久久久久久蜜桃| 欧美三级黄美女| 欧美成人dvd在线视频| 国产精品嫩草久久久久| 最新国产精品拍自在线播放| 国产一区二区主播在线| 一区二区三区高清不卡| 亚洲欧洲中文日韩久久av乱码| 久久成年人视频| 久久国产精品网站| 国产精品久久久久久久久久尿 | 国产精品美女久久久久av超清| 免费在线播放第一区高清av| 国产欧美日韩亚洲精品| 在线视频精品| 亚洲视屏在线播放| 欧美黄网免费在线观看| 欧美成人免费在线视频| 一区二区自拍| 久久久精品午夜少妇| 久久久久成人网| 欧美日韩视频一区二区| 91久久精品日日躁夜夜躁国产| 在线观看日韩国产| 久久婷婷蜜乳一本欲蜜臀| 久久另类ts人妖一区二区| 国产欧美不卡| 欧美在线观看网址综合| 久久精品国产久精国产爱| 国产欧美日韩激情| 欧美在线免费| 久久综合一区二区| 亚洲国产高清高潮精品美女| 老色鬼精品视频在线观看播放| 美女啪啪无遮挡免费久久网站| 好吊妞**欧美| 免费中文字幕日韩欧美| 亚洲伦理在线观看| 亚洲欧美精品中文字幕在线| 国产精品一区二区久激情瑜伽| 亚洲在线日韩| 久久夜色精品国产亚洲aⅴ| 亚洲黄色成人| 欧美日韩在线播放一区| 亚洲尤物在线| 免费日韩视频| 在线视频精品一区| 国产日韩欧美二区| 久久夜色精品国产| 99热免费精品| 久久丁香综合五月国产三级网站| 国产亚洲欧美一区二区| 久久久久99| 日韩亚洲成人av在线| 欧美在线播放| 亚洲精品美女| 国产精品一区二区你懂得| 久久噜噜噜精品国产亚洲综合| 亚洲第一中文字幕在线观看| 亚洲永久在线| 黑丝一区二区三区| 欧美日韩一区免费| 久久久精品一品道一区| 一区二区三区久久网| 久久中文精品| 一区二区av在线| 狠狠88综合久久久久综合网| 欧美日本国产视频| 久久se精品一区二区| 一本一道久久综合狠狠老精东影业 | 国产精品嫩草99a| 久久人91精品久久久久久不卡| 亚洲日韩欧美视频| 久久国产精品一区二区| 一区二区日韩免费看| 依依成人综合视频| 国产精品视频最多的网站| 欧美国产91| 久久女同精品一区二区| 亚洲一区二区三区四区视频| 亚洲黄一区二区| 美女精品国产| 久久九九免费| 亚洲欧美日韩综合一区| 一区二区三区成人| 91久久夜色精品国产九色| 国内精品伊人久久久久av一坑| 欧美日韩午夜| 欧美精品久久久久久久久老牛影院| 欧美一区影院| 午夜欧美精品久久久久久久| 亚洲素人在线| 一区二区高清| 一本一本久久a久久精品综合妖精| 亚洲第一精品夜夜躁人人爽| 久久久久免费观看| 久久久精品五月天| 久久精品国产第一区二区三区| 午夜视频久久久久久| 亚洲一区影院| 午夜精品久久久久久久蜜桃app| 一本色道久久综合狠狠躁的推荐| 亚洲人妖在线| 亚洲精品视频在线| 日韩视频在线永久播放| 99国内精品| 亚洲天堂男人| 午夜影视日本亚洲欧洲精品| 亚洲一区网站| 欧美在线视频播放| 久久综合色天天久久综合图片| 久久婷婷色综合| 美女在线一区二区| 欧美黄色精品| 亚洲精品久久久久久久久久久 | 久久精品三级| 老司机aⅴ在线精品导航| 男女精品网站| 亚洲黄一区二区三区| 在线视频日本亚洲性| 午夜精品一区二区三区在线视| 久久av一区二区三区亚洲| 久久久久久国产精品一区| 欧美成年人视频| 欧美日韩亚洲一区二| 国产精品一二三视频| 伊人精品视频| 一区二区欧美亚洲| 欧美在线三区| 亚洲国产91色在线| 国产精品99久久久久久宅男 | 亚洲精品视频在线观看免费| 洋洋av久久久久久久一区| 午夜精品久久久久久久久久久久久 | 久久精品国产久精国产爱| 免费成人av资源网| 国产精品h在线观看| 韩国v欧美v日本v亚洲v| 亚洲美女色禁图| 欧美一区二区视频在线观看| 欧美99在线视频观看| 一区二区三区国产在线| 久久久久久高潮国产精品视| 欧美婷婷六月丁香综合色| 一色屋精品视频在线观看网站| 99精品热视频只有精品10| 久久漫画官网| 99在线热播精品免费99热| 久久噜噜亚洲综合| 国产精品视频免费在线观看| 亚洲国产一成人久久精品| 欧美一区二区三区久久精品茉莉花 | 小黄鸭精品密入口导航| 欧美1区视频| 欧美亚洲综合网| 欧美系列一区| 亚洲人成在线观看| 久久亚洲私人国产精品va| 99综合在线| 欧美国产精品va在线观看| 在线观看一区二区精品视频| 欧美影院成人|