锘??xml version="1.0" encoding="utf-8" standalone="yes"?>色成年激情久久综合,www.久久热.com,日本精品久久久久中文字幕http://www.shnenglu.com/NicYun/category/9721.html鍩虹鐭ヨ瘑瀛︿範zh-cnFri, 13 Mar 2009 04:15:48 GMTFri, 13 Mar 2009 04:15:48 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 鍙戣〃璇勮
]]>
久久精品国产99国产精品亚洲| 九九精品99久久久香蕉| 久久久精品国产亚洲成人满18免费网站 | 国产精品成人久久久久久久| 欧美精品一区二区精品久久| 九九久久精品无码专区| 久久精品国产99国产精品导航| AV无码久久久久不卡蜜桃| 久久丝袜精品中文字幕| 色欲综合久久躁天天躁蜜桃| 一本色道久久88加勒比—综合| 亚洲国产精品一区二区三区久久 | 国产精品欧美亚洲韩国日本久久| 人妻中文久久久久| 久久国产精品成人影院| 久久久久国产一级毛片高清板| 久久久一本精品99久久精品88| 久久人人超碰精品CAOPOREN| 国产一级做a爰片久久毛片| yy6080久久| 久久久精品无码专区不卡| 99久久无码一区人妻a黑| 热99RE久久精品这里都是精品免费 | 久久精品成人免费观看97| 99re久久精品国产首页2020| 国产精品乱码久久久久久软件| 精品久久久久中文字幕一区| 国产精品久久毛片完整版| 久久综合给合久久国产免费| 国产精品久久久久a影院| 久久久精品日本一区二区三区| 久久香蕉一级毛片| 国产精品久久久久影院嫩草| 久久99国产综合精品| 久久精品国产亚洲AV无码麻豆| 日本WV一本一道久久香蕉| 亚洲精品WWW久久久久久| 人妻无码精品久久亚瑟影视| 婷婷久久精品国产| 久久精品免费一区二区| 99久久无色码中文字幕人妻|