锘??xml version="1.0" encoding="utf-8" standalone="yes"?>精品伊人久久大线蕉色首页,精品久久久久久久国产潘金莲 ,2021久久国自产拍精品http://m.shnenglu.com/NicYun/鍩虹鐭ヨ瘑瀛︿範zh-cnFri, 09 May 2025 03:37:39 GMTFri, 09 May 2025 03:37:39 GMT60鏍戠姸鏁扮粍http://m.shnenglu.com/NicYun/archive/2009/03/13/76415.htmlNicYunNicYunFri, 13 Mar 2009 03:30:00 GMThttp://m.shnenglu.com/NicYun/archive/2009/03/13/76415.htmlhttp://m.shnenglu.com/NicYun/comments/76415.htmlhttp://m.shnenglu.com/NicYun/archive/2009/03/13/76415.html#Feedback0http://m.shnenglu.com/NicYun/comments/commentRss/76415.htmlhttp://m.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://m.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://m.shnenglu.com/NicYun/archive/2009/03/08/75932.html</guid><wfw:comment>http://m.shnenglu.com/NicYun/comments/75932.html</wfw:comment><comments>http://m.shnenglu.com/NicYun/archive/2009/03/08/75932.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://m.shnenglu.com/NicYun/comments/commentRss/75932.html</wfw:commentRss><trackback:ping>http://m.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://m.shnenglu.com/NicYun/aggbug/75932.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://m.shnenglu.com/NicYun/" target="_blank">NicYun</a> 2009-03-08 21:02 <a href="http://m.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://m.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://m.shnenglu.com/NicYun/archive/2008/08/05/58037.html</guid><wfw:comment>http://m.shnenglu.com/NicYun/comments/58037.html</wfw:comment><comments>http://m.shnenglu.com/NicYun/archive/2008/08/05/58037.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://m.shnenglu.com/NicYun/comments/commentRss/58037.html</wfw:commentRss><trackback:ping>http://m.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://m.shnenglu.com/NicYun/aggbug/58037.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://m.shnenglu.com/NicYun/" target="_blank">NicYun</a> 2008-08-05 09:24 <a href="http://m.shnenglu.com/NicYun/archive/2008/08/05/58037.html#Feedback" target="_blank" style="text-decoration:none;">鍙戣〃璇勮</a></div>]]></description></item><item><title>鏈灝忓爢鍜屾渶澶у爢http://m.shnenglu.com/NicYun/archive/2008/08/04/57934.htmlNicYunNicYunMon, 04 Aug 2008 02:29:00 GMThttp://m.shnenglu.com/NicYun/archive/2008/08/04/57934.htmlhttp://m.shnenglu.com/NicYun/comments/57934.htmlhttp://m.shnenglu.com/NicYun/archive/2008/08/04/57934.html#Feedback0http://m.shnenglu.com/NicYun/comments/commentRss/57934.htmlhttp://m.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 鍙戣〃璇勮
]]>
久久久久人妻一区二区三区| 2021久久国自产拍精品| 国产99久久久国产精免费| 久久无码精品一区二区三区| 一本久久a久久精品综合香蕉 | 国产精品亚洲美女久久久| 亚洲国产精品无码久久久久久曰| 亚洲中文精品久久久久久不卡| 久久99免费视频| 一级做a爰片久久毛片看看| 精品无码久久久久国产| 欧美伊人久久大香线蕉综合69| 久久久久免费看成人影片| 色播久久人人爽人人爽人人片aV| 久久国产色av免费看| 久久精品国产一区二区电影| a高清免费毛片久久| 国产成年无码久久久免费| 久久精品视屏| 国内精品久久久久久不卡影院| 欧美熟妇另类久久久久久不卡| 无码任你躁久久久久久老妇| 国产日韩欧美久久| 伊人久久大香线焦综合四虎| 天天躁日日躁狠狠久久| 成人久久免费网站| 亚洲国产精品一区二区三区久久| 国产精品99久久久久久董美香| 久久97精品久久久久久久不卡| 狠狠色丁香久久婷婷综合| 欧美国产成人久久精品| 欧美一级久久久久久久大| 久久中文字幕无码专区| 久久久青草青青国产亚洲免观| Xx性欧美肥妇精品久久久久久| 99久久免费国产精品| 伊人久久大香线蕉精品| 精品国产综合区久久久久久 | 久久青青草视频| 久久福利资源国产精品999| 伊人久久大香线蕉综合热线|