<?xml version="1.0" encoding="gb2312"?>
<rss version="2.0">
<channel>
<title><![CDATA[小用的空间]]></title>
        <image>
        <title>http://hi.baidu.com</title>
        <link>http://hi.baidu.com</link>
        <url>http://img.baidu.com/img/logo-hi.gif</url>
        </image>
<description><![CDATA[ACM/ICPC TopCoder Algorithm Mathematics C/C++  Genericity/STL Programming Language Linux]]></description>
<link>http://hi.baidu.com/wuxyy</link>
<language>zh-cn</language>
<generator>www.baidu.com</generator>
<ttl>5</ttl>


<item>
        <title><![CDATA[2008年ACM/ICPC亚洲区预赛中国大陆各个赛区日程安排]]></title>
        <link><![CDATA[http://hi.baidu.com/wuxyy/blog/item/3f84ff1fa192d20c314e1560.html]]></link>
        <description><![CDATA[
		
		<div class="postcolor">
<p><font size="2">1、哈尔滨赛区（哈尔滨工程大学）<br>
网络选拔赛日期：9月20日<br>
现场赛日期：10月11～12</font></p>
<p><font size="2">2、北京赛区（北京交通大学）<br>
网络选拔赛日期：9月30日<br>
现场赛日期：10月25～26</font></p>
<p><font size="2">3、合肥赛区（中国科学技术大学）<br>
网络选拔赛日期：9月29日<br>
现场赛日期：11月15～16</font></p>
<p><font size="2">4、杭州赛区（杭州电子科技大学）<br>
网络选拔赛日期：10月18日<br>
现场赛日期：11月22～23</font></p>
<p><font size="2">5、成都赛区（西南民族学院）<br>
网络选拔赛日期：10月19日<br>
现场赛日期：11月29～30<br>
</font></p>
</div> <a href="http://hi.baidu.com/wuxyy/blog/item/3f84ff1fa192d20c314e1560.html">阅读全文</a>
		
		<br/><b>类别：</b><a href="http://hi.baidu.com/wuxyy/blog/category/acm%26%2347%3Bicpc">acm&#47;icpc</a>&nbsp;<a href="http://hi.baidu.com/wuxyy/blog/item/3f84ff1fa192d20c314e1560.html#comment">查看评论</a>]]></description>
        <pubDate>2008-08-09  23:05</pubDate>
        <category><![CDATA[acm&#47;icpc]]></category>
        <author><![CDATA[wuxyy]]></author>
		<guid>http://hi.baidu.com/wuxyy/blog/item/3f84ff1fa192d20c314e1560.html</guid>
</item>

<item>
        <title><![CDATA[Google Code Jam 2008 results]]></title>
        <link><![CDATA[http://hi.baidu.com/wuxyy/blog/item/ae56233f0f6443ea54e723ac.html]]></link>
        <description><![CDATA[
		
		<p><font size="2">半夜跑到公司比赛，2个小时4个题目，时间有点紧，B题出了点问题，没弄出来，还好其他两题做得比较快，才能排进全球Top1000,星期六冲击Top500，进军北京Google，-,-</font></p>
<p><font size="2">Congratulations! The results of Google Code Jam 2008 Round 2 are now official, and we're happy to announce that you have advanced to Round 3.<br>
<br>
Online Round 3 will take place on Saturday, August 9 at 16:00 UTC.<br>
<br>
The top-scoring 500 finalists from that round will get a chance to participate in the local onsites, which will take place at Google offices around the world!<br>
<br>
For more details, please visit </font><a href="http://code.google.com/codejam/rules.html" target="_blank"><font size="2">http://code.google.com/<wbr></wbr>codejam/rules.html</font></a><font size="2">.<br>
<br>
Congratulations again on qualifying for Round 3 of the Google Code Jam 2008!<br>
<br>
- The Google Code Jam Team</font></p> <a href="http://hi.baidu.com/wuxyy/blog/item/ae56233f0f6443ea54e723ac.html">阅读全文</a>
		
		<br/><b>类别：</b><a href="http://hi.baidu.com/wuxyy/blog/category/Contest">Contest</a>&nbsp;<a href="http://hi.baidu.com/wuxyy/blog/item/ae56233f0f6443ea54e723ac.html#comment">查看评论</a>]]></description>
        <pubDate>2008-08-05  11:50</pubDate>
        <category><![CDATA[Contest]]></category>
        <author><![CDATA[wuxyy]]></author>
		<guid>http://hi.baidu.com/wuxyy/blog/item/ae56233f0f6443ea54e723ac.html</guid>
</item>

<item>
        <title><![CDATA[Astar2008百度之星复赛通知]]></title>
        <link><![CDATA[http://hi.baidu.com/wuxyy/blog/item/169c3bdb1146f763d1164e7c.html]]></link>
        <description><![CDATA[
		
		<p style="font-size: 12px"><font size="2"><strong>wuxy，您好！ </strong><br>
<br>
祝贺您成功晋级Astar2008百度之星程序设计大赛复赛阶段的比赛！ <br>
您已经获得了由百度之星程序设计大赛提供的大赛限量纪念版T恤一件，请您登录自己的帐号完善通讯联系方式，以便我们邮寄并且确保您能收到奖品。 <br>
<br>
复赛将于2008年6月14日暨本周六 9:00 至 21:00 进行，您可以在系统提供的 12 个小时内选择8小时进行答题，总答题时间不能超过8小时。 <br>
复赛的赛事规则详细参见百度之星官方网站 </font><a target="_blank" href="http://star.baidu.com/rules.html"><font size="2">赛事规则</font></a><font size="2"> 。 <br>
我们将邀请从复赛中晋级的50名选手在7月中旬到北京参加为期3天的总决赛。 <br>
<br>
入围复赛后，您的信息已经自动进入百度公司人才库，并有机会优先参与百度实习生&ldquo;绿色通道&rdquo;计划，在实习生招聘过程中将免去笔试环节，并且可以减免一轮面试。 <br>
如果您能晋级总决赛，将直接获得百度实习Offer，进入百度实习，接受技术牛人指导职业发展，接触搜索引擎核心技术。欢迎您登录帐号更新简历。 <br>
比赛详情请关注百度之星官方网站和百度贴吧，我们也将在大赛官方百度Hi群及时公布相关信息。大赛已经开通了官方交流百度Hi群，欢迎交流讨论。 <br>
大赛官方交流百度Hi群号：1001062，1001102，1000827，1000836，1001059，1001053，1001103，1000821 <br>
<br>
最后预祝您在复赛中取得优异的成绩！ <br>
<br>
<span style="color: red">感谢您的反馈！</span></font></p>
<div class="box_1">
<p><font size="2">Astar2008百度之星程序设计大赛组委会</font></p>
</div> <a href="http://hi.baidu.com/wuxyy/blog/item/169c3bdb1146f763d1164e7c.html">阅读全文</a>
		
		<br/><b>类别：</b><a href="http://hi.baidu.com/wuxyy/blog/category/Contest">Contest</a>&nbsp;<a href="http://hi.baidu.com/wuxyy/blog/item/169c3bdb1146f763d1164e7c.html#comment">查看评论</a>]]></description>
        <pubDate>2008-06-11  21:59</pubDate>
        <category><![CDATA[Contest]]></category>
        <author><![CDATA[wuxyy]]></author>
		<guid>http://hi.baidu.com/wuxyy/blog/item/169c3bdb1146f763d1164e7c.html</guid>
</item>

<item>
        <title><![CDATA[GDCPC&#39;2008 SuperMario]]></title>
        <link><![CDATA[http://hi.baidu.com/wuxyy/blog/item/bf6f1d30d3daea9ca8018e3f.html]]></link>
        <description><![CDATA[
		
		<p><font size="2">这次比赛起了个队名叫SuperMario，不过没发挥好，没对得起SuperMario.<br>
去年的GDCPC，G题的rejudge让比赛结果变得不可预测，最终只拿到三等奖，当时非常郁闷。<br>
今年，题目描述没有出现问题了，但五个小时后依然只拿到三等奖，不过这次没有什么感觉了，可能是现在没把比赛看得那么重了。。。其实我好久没做题了，水掉省赛也是正常的。<br>
觉得这两年省赛的题目简单题太多了，中等题难度不够，对我非常不利，两年都碰到时间不够的情况，也许是我的coding太弱吧。。。</font></p>
<p><font size="2">四道简单题：</font></p>
<p><font size="2">A题：评委说这是一道不会编程的人也能AC的题目。4分钟秒掉，比起大牛还是慢了点。</font></p>
<p><font size="2">I题：判断点是否在圆内，依然是几分钟就能搞定的题目。</font></p>
<p><font size="2">J题：判断两个数是否相等且能被11整除，由于数字长度高达1000位，而又没想到数学方法，就只能敲了个高精度除以低精度的代码。赛后评委说这是个小学数学问题，一个数是否能被11整除可以通过计算奇数位总和和偶数位总和的差是否为11的倍数来判断。</font></p>
<p><font size="2">B题：做这题的赛后没想清楚就拼命敲代码，wa后才想清楚，重新敲代码，又是一道十分钟内的题目。对题目给出的无向图，先求出每个连通子图，然后在每个连通图里分别找出最小的time(即先读这本书)，而其它书都只需要一半的时间读。</font></p>
<p><font size="2">两道中等题：</font></p>
<p><font size="2">F题：5^8的广度优先搜索，根据题目规则进行变换，状态表示弄清楚就好了，跟之前珠海赛的题目类似。</font></p>
<p><font size="2">C题：中等偏易的模拟题，题目看清楚，分析好情况即可，可惜最后没做完。</font></p>
<p><font size="2">剩下四道题难度都比较大，D题几何题，E题树形DP，G题看起来会TLE的最小生成树，H题用到容斥定理和中国剩余定理的数论题。</font></p>
<p><font size="2">111个队伍的做题情况</font></p>
<p><font size="2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 通过队数&nbsp;&nbsp; 最早过题时间&nbsp;&nbsp;&nbsp;  通过率<br>
A&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  111&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  82.84%<br>
B&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  76&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  16&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  21.84%<br>
I&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  108&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  10&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  76.06%<br>
J&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  94&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  10&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  31.23%<br>
C&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  47&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  106&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  26.11%<br>
F&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  40&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  90&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  32.00%<br>
D&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  1&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  189&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  2.77%<br>
E&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  155&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  10.53%<br>
G&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  1&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  250&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5.26%<br>
H&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  155&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  2.02%<br>
</font></p>
<p><font size="2">GDCPC2008 standing</font></p>
<p><font size="2">rank&nbsp;&nbsp;&nbsp;  solved  penalty teamname<br>
<font class="37">1&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  8&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  787&nbsp;&nbsp;&nbsp;&nbsp;  SCUT_Scintilla<br>
</font><font class="37">2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  8&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  812&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_Dandelion<br>
</font><font class="37">3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  7&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  718&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_take_away<br>
</font><font class="37">4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  7&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  808&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_overGround<br>
</font><font class="37">5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  7&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  896&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_The No.1 Middle School of Shaoguan<br>
</font><font class="37">6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  7&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  1037&nbsp;&nbsp;&nbsp;  ZSU_DouDiZhu@MoMoTea<br>
</font><font class="37">7&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  434&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_Happy<br>
</font><font class="37">8&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  438&nbsp;&nbsp;&nbsp;&nbsp;  ZSU*_SilverBullet<br>
</font><font class="37">9&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  458&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_BruteForce<br>
</font><font class="37">10&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  499&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_Mosaic<br>
</font><font class="37">11&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  533&nbsp;&nbsp;&nbsp;&nbsp;  GDUT_ A NEW HOPE<br>
</font><font class="37">12&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  540&nbsp;&nbsp;&nbsp;&nbsp;  SCAU_LLL<br>
</font><font class="37">13&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  540&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_Noskill<br>
</font><font class="37">14&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  549&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_Ctrl+A-Ctrl+C-Ctrl+V-AC<br>
</font><font class="37">15&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  605&nbsp;&nbsp;&nbsp;&nbsp;  BNUEP_int_ijk<br>
</font><font class="37">16&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  608&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_Super Math_3<br>
</font><font class="37">17&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  611&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_Transparent<br>
</font><font class="37">18&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  624&nbsp;&nbsp;&nbsp;&nbsp;  SCNU_1<br>
</font><font class="37">19&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  639&nbsp;&nbsp;&nbsp;&nbsp;  SCAU_VeryYellowVeryBruteForce<br>
</font><font class="37">20&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  673&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_for_advertisement<br>
</font><font class="37">21&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  686&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_FinalFantasy<br>
</font><font class="37">22&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  692&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_Cybele<br>
</font><font class="37">23&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  695&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_Icecream<br>
</font><font class="37">24&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  700&nbsp;&nbsp;&nbsp;&nbsp;  SCUT_Solar<br>
</font><font class="37">25&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  728&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_void main()<br>
</font><font class="37">26&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  731&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_Strawberry&amp;Apple&amp;Orange<br>
</font><font class="37">27&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  770&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_C.Z.Z<br>
</font><font class="37">28&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  786&nbsp;&nbsp;&nbsp;&nbsp;  JNU_ZZCY<br>
</font><font class="37">29&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  816&nbsp;&nbsp;&nbsp;&nbsp;  BNUEP_Leave_Me_Alone<br>
</font><font class="37">30&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  890&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_Fyronice<br>
</font><font class="37">31&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  940&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_YJ_Big_Robbers<br>
</font><font class="37">32&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  1050&nbsp;&nbsp;&nbsp;  ZSU_Jump To Winsweet<br>
</font><font class="37">33&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  1104&nbsp;&nbsp;&nbsp;  WYU_Pro_orZ<br>
</font><font class="37">34&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  287&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_AbsE<br>
</font><font class="37">35&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  326&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_Euclid<br>
</font><font class="37">36&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  356&nbsp;&nbsp;&nbsp;&nbsp;  DGUT_rush<br>
</font><font class="37">37&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  374&nbsp;&nbsp;&nbsp;&nbsp;  STU_jjyy<br>
</font><font class="37">38&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  432&nbsp;&nbsp;&nbsp;&nbsp;  BNUEP_TalentPanda<br>
</font><font class="37">39&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  479&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_GEASS<br>
</font><font class="37">40&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  496&nbsp;&nbsp;&nbsp;&nbsp;  GZHU_Z.W.L<br>
</font><font class="37">41&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  506&nbsp;&nbsp;&nbsp;&nbsp;  SZU_Rexploiter<br>
</font><font class="37">42&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  516&nbsp;&nbsp;&nbsp;&nbsp;  SCNU_9<br>
</font><font class="37">43&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  547&nbsp;&nbsp;&nbsp;&nbsp;  JNU_MP3<br>
</font><font class="37">44&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  570&nbsp;&nbsp;&nbsp;&nbsp;  GDUT_SEAFOOD<br>
</font><font class="37">45&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  585&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_Nightingale<br>
</font><font class="37">46&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  597&nbsp;&nbsp;&nbsp;&nbsp;  SCAU_AC++<br>
</font><font class="37">47&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  623&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_suibian<br>
</font><font class="37">48&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  626&nbsp;&nbsp;&nbsp;&nbsp;  JLUZH_SuperMario<br>
</font><font class="37">49&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  641&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_honorificabilitudinitatibus<br>
</font><font class="37">50&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  657&nbsp;&nbsp;&nbsp;&nbsp;  SCAU_CFFcFIA<br>
</font><font class="37">51&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  669&nbsp;&nbsp;&nbsp;&nbsp;  SCAU_Picasso<br>
</font><font class="37">52&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  679&nbsp;&nbsp;&nbsp;&nbsp;  BNUEP_APEX<br>
</font><font class="37">53&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  696&nbsp;&nbsp;&nbsp;&nbsp;  SCUT_Cinderella<br>
</font><font class="37">54&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  805&nbsp;&nbsp;&nbsp;&nbsp;  GZHU_RPOverFlow<br>
</font><font class="37">55&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  1174&nbsp;&nbsp;&nbsp;  ZSU_LittleSweetie<br>
</font><font class="37">56&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  205&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_AC<br>
</font><font class="37">57&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  206&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_C Plus Plus<br>
</font><font class="37">58&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  233&nbsp;&nbsp;&nbsp;&nbsp;  WYU_Rocket<br>
</font><font class="37">59&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  240&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_Visy.ta<br>
</font><font class="37">60&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  264&nbsp;&nbsp;&nbsp;&nbsp;  SGU_CPC<br>
</font><font class="37">61&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  343&nbsp;&nbsp;&nbsp;&nbsp;  SZU_MarsDesperado<br>
</font><font class="37">62&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  346&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_Old friends<br>
</font><font class="37">63&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  352&nbsp;&nbsp;&nbsp;&nbsp;  SCNU_2<br>
</font><font class="37">64&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  354&nbsp;&nbsp;&nbsp;&nbsp;  STU_NewBee<br>
</font><font class="37">65&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  388&nbsp;&nbsp;&nbsp;&nbsp;  JNU_Spark<br>
</font><font class="37">66&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  425&nbsp;&nbsp;&nbsp;&nbsp;  SZU_WINGOES<br>
</font><font class="37">67&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  429&nbsp;&nbsp;&nbsp;&nbsp;  GDIT_D-winds<br>
</font><font class="37">68&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  435&nbsp;&nbsp;&nbsp;&nbsp;  STU_Ray <br>
</font><font class="37">69&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  449&nbsp;&nbsp;&nbsp;&nbsp;  GDUT_GALAXY<br>
</font><font class="37">70&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  502&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_ShiningFinger<br>
</font><font class="37">71&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  523&nbsp;&nbsp;&nbsp;&nbsp;  SCNU_5<br>
</font><font class="37">72&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  560&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_unbelievable<br>
</font><font class="37">73&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  566&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_fireflies<br>
</font><font class="37">74&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  679&nbsp;&nbsp;&nbsp;&nbsp;  GZHU_ForBest<br>
</font><font class="37">75&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  717&nbsp;&nbsp;&nbsp;&nbsp;  SCNU_7<br>
</font><font class="37">76&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  81&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_navigator<br>
</font><font class="37">77&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  155&nbsp;&nbsp;&nbsp;&nbsp;  BNUEP_ShortHair<br>
</font><font class="37">78&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  165&nbsp;&nbsp;&nbsp;&nbsp;  ZHBIT_Yuan<br>
</font><font class="37">79&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  185&nbsp;&nbsp;&nbsp;&nbsp;  SCNU_3<br>
</font><font class="37">80&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  218&nbsp;&nbsp;&nbsp;&nbsp;  ZSC_Miracle<br>
</font><font class="37">81&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  222&nbsp;&nbsp;&nbsp;&nbsp;  GDCC_Challenge-A<br>
</font><font class="37">82&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  254&nbsp;&nbsp;&nbsp;&nbsp;  SCAU_VeryGoodVeryPowerful<br>
</font><font class="37">83&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  262&nbsp;&nbsp;&nbsp;&nbsp;  SCNU_8<br>
</font><font class="37">84&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  263&nbsp;&nbsp;&nbsp;&nbsp;  GZHU_silence<br>
</font><font class="37">85&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  274&nbsp;&nbsp;&nbsp;&nbsp;  SZU_110<br>
</font><font class="37">86&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  303&nbsp;&nbsp;&nbsp;&nbsp;  GDCC-Cordro-C<br>
</font><font class="37">87&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  306&nbsp;&nbsp;&nbsp;&nbsp;  ZSU_Elephants<br>
</font><font class="37">88&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  338&nbsp;&nbsp;&nbsp;&nbsp;  DGUT_bluewing<br>
</font><font class="37">89&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  356&nbsp;&nbsp;&nbsp;&nbsp;  SCNU_6<br>
</font><font class="37">90&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  376&nbsp;&nbsp;&nbsp;&nbsp;  GDUFS_Try Our Best<br>
</font><font class="37">91&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  381&nbsp;&nbsp;&nbsp;&nbsp;  JLUZH_MarioBrothers<br>
</font><font class="37">92&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  382&nbsp;&nbsp;&nbsp;&nbsp;  SCNU_4<br>
</font><font class="37">93&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  404&nbsp;&nbsp;&nbsp;&nbsp;  GPNU_WRQ<br>
</font><font class="37">94&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  432&nbsp;&nbsp;&nbsp;&nbsp;  ZSC_Hope<br>
</font><font class="37">95&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  440&nbsp;&nbsp;&nbsp;&nbsp;  GDCC-Beyond-E<br>
</font><font class="37">96&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  467&nbsp;&nbsp;&nbsp;&nbsp;  GZHU_Z.X.K<br>
</font><font class="37">97&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  61&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  ZQU_NGU<br>
</font><font class="37">98&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  94&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  GPNU_COOLEE<br>
</font><font class="37">99&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  100&nbsp;&nbsp;&nbsp;&nbsp;  GDCC_Firefly-B<br>
</font><font class="37">100&nbsp;&nbsp;&nbsp;&nbsp;  2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  104&nbsp;&nbsp;&nbsp;&nbsp;  FOSU_ZTX<br>
</font><font class="37">101&nbsp;&nbsp;&nbsp;&nbsp;  2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  119&nbsp;&nbsp;&nbsp;&nbsp;  WYU_Cscoder<br>
</font><font class="37">102&nbsp;&nbsp;&nbsp;&nbsp;  2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  132&nbsp;&nbsp;&nbsp;&nbsp;  ZQU_ShareACM<br>
</font><font class="37">103&nbsp;&nbsp;&nbsp;&nbsp;  2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  166&nbsp;&nbsp;&nbsp;&nbsp;  GDOU_LXZ<br>
</font><font class="37">104&nbsp;&nbsp;&nbsp;&nbsp;  2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  172&nbsp;&nbsp;&nbsp;&nbsp;  ZHBIT_lly<br>
</font><font class="37">105&nbsp;&nbsp;&nbsp;&nbsp;  2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  185&nbsp;&nbsp;&nbsp;&nbsp;  GPNU_TOMORROW<br>
</font><font class="37">106&nbsp;&nbsp;&nbsp;&nbsp;  2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  193&nbsp;&nbsp;&nbsp;&nbsp;  ZQU_Beginer<br>
</font><font class="37">107&nbsp;&nbsp;&nbsp;&nbsp;  2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  207&nbsp;&nbsp;&nbsp;&nbsp;  ZHBIT_do_it<br>
</font><font class="37">108&nbsp;&nbsp;&nbsp;&nbsp;  2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  214&nbsp;&nbsp;&nbsp;&nbsp;  GDIT_Snipers<br>
</font><font class="37">109&nbsp;&nbsp;&nbsp;&nbsp;  1&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  17&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  FOSU_606<br>
</font><font class="37">110&nbsp;&nbsp;&nbsp;&nbsp;  1&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  19&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  GDCC-JDI-D<br>
</font><font class="37">111&nbsp;&nbsp;&nbsp;&nbsp;  1&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  527&nbsp;&nbsp;&nbsp;&nbsp;  NII_X<br>
</font></font></p> <a href="http://hi.baidu.com/wuxyy/blog/item/bf6f1d30d3daea9ca8018e3f.html">阅读全文</a>
		
		<br/><b>类别：</b><a href="http://hi.baidu.com/wuxyy/blog/category/acm%26%2347%3Bicpc">acm&#47;icpc</a>&nbsp;<a href="http://hi.baidu.com/wuxyy/blog/item/bf6f1d30d3daea9ca8018e3f.html#comment">查看评论</a>]]></description>
        <pubDate>2008-05-11  12:03</pubDate>
        <category><![CDATA[acm&#47;icpc]]></category>
        <author><![CDATA[wuxyy]]></author>
		<guid>http://hi.baidu.com/wuxyy/blog/item/bf6f1d30d3daea9ca8018e3f.html</guid>
</item>

<item>
        <title><![CDATA[SRM 382 —— 终于升上div1了]]></title>
        <link><![CDATA[http://hi.baidu.com/wuxyy/blog/item/3613af34aa585eb4d1a2d352.html]]></link>
        <description><![CDATA[
		
		<p><font size="2">已经快两个月没做srm了，这次的时间正好是白天，于是跷课来做tc。</font></p>
<p><font size="2">第三题想不出来，前两题估计没什么问题。System test后排名升到18. Rating升了108，变成蓝色<font color="#0000ff">handle</font>了，下次去div1玩咯。。。</font></p> 
		
		<br/><b>类别：</b><a href="http://hi.baidu.com/wuxyy/blog/category/Topcoder">Topcoder</a>&nbsp;<a href="http://hi.baidu.com/wuxyy/blog/item/3613af34aa585eb4d1a2d352.html#comment">查看评论</a>]]></description>
        <pubDate>2007-12-12  12:01</pubDate>
        <category><![CDATA[Topcoder]]></category>
        <author><![CDATA[wuxyy]]></author>
		<guid>http://hi.baidu.com/wuxyy/blog/item/3613af34aa585eb4d1a2d352.html</guid>
</item>

<item>
        <title><![CDATA[POJ2513 Colored Sticks —— Trie树 + 并查集]]></title>
        <link><![CDATA[http://hi.baidu.com/wuxyy/blog/item/6a484334229b414d251f1488.html]]></link>
        <description><![CDATA[
		
		<p><a target="_blank" href="http://acm.pku.edu.cn/JudgeOnline/problem?id=2513">POJ2513 Colored Sticks</a></p>
<p>这道题需要判断图的连通性和欧拉回路，我的程序用了并查集判断图的连通性，用Trie树（用Hash效果也不错）统计单词出现次数，即统计的顶点的度数以此判断该图是否存在欧拉回路。</p>
<p> </p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt; COLOR: blue;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes">#include</span><span style="FONT-SIZE: 14pt; COLOR: maroon;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes">&lt;iostream&gt;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt; COLOR: blue;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes">using</span><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"> <span style="COLOR: blue">namespace</span> std;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt; COLOR: blue;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes">#define</span><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"> N 500010</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt; COLOR: blue;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes">struct</span><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"> Node</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes">{</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">int</span> id;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span>Node *p[26];</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span>Node()</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span>{</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">int</span> i;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>id=-1;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">for</span> (i=0;i&lt;26;i++)</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 3">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>p[i]=NULL;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span>}</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes">}root;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt; COLOR: blue;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes">int</span><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"> d[N],parent[N],rank[N],cnt;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt; COLOR: blue;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes">int</span><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"> GetNum(<span style="COLOR: blue">char</span> *s)</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes">{</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">int</span> i;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span>Node *r=&amp;root;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">for</span> (i=0;s[i];i++)</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span>{</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">if</span> (r-&gt;p[s[i]-<span style="COLOR: maroon">'a'</span>]==NULL)</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 3">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>r-&gt;p[s[i]-<span style="COLOR: maroon">'a'</span>]=<span style="COLOR: blue">new</span> Node();</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>r=r-&gt;p[s[i]-<span style="COLOR: maroon">'a'</span>];</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span>}</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">if</span> (r-&gt;id==-1)</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>r-&gt;id=cnt++;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">return</span> r-&gt;id;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes">}</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt; COLOR: blue;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes">int</span><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"> FindSet(<span style="COLOR: blue">int</span> i)</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes">{</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">if</span> (parent[i]!=i)</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>parent[i]=FindSet(parent[i]);</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">return</span> parent[i];</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes">}</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt; COLOR: blue;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes">int</span><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"> UnionSet(<span style="COLOR: blue">int</span> i,<span style="COLOR: blue">int</span> j)</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes">{</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span>i=FindSet(i);</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span>j=FindSet(j);</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">if</span> (i!=j)</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">if</span> (rank[i]&gt;rank[j])</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 3">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>parent[j]=i;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">else</span></span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>{</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 3">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>parent[i]=j;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 3">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">if</span> (rank[i]==rank[j])</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 4">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>++rank[j];</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>}</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">return</span> i!=j;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes">}</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt; COLOR: blue;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes">int</span><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"> main()</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes">{</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">int</span> i,j,k;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">char</span> s1[12],s2[12];</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">for</span> (i=0;i&lt;N;i++)</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>parent[i]=i;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span>cnt=0;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span>memset(rank,0,<span style="COLOR: blue">sizeof</span>(rank));</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span>memset(d,0,<span style="COLOR: blue">sizeof</span>(d));</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">while</span> (scanf(<span style="COLOR: maroon">"%s%s"</span>,s1,s2)!=EOF)</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span>{</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>j=GetNum(s1);</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>k=GetNum(s2);</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>d[j]++;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>d[k]++;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>UnionSet(j,k);</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span>}</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">for</span> (k=i=0;i&lt;cnt;i++)</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">if</span> (d[i]%2)</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 3">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>k++;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span>j=FindSet(0);</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">for</span> (i=1;i&lt;cnt;i++)</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">if</span> (FindSet(i)!=j)</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>{</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 3">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>printf(<span style="COLOR: maroon">"Impossible\n"</span>);</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 3">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">return</span> 0;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>}</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">if</span> (k&lt;3)</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>printf(<span style="COLOR: maroon">"Possible\n"</span>);</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">else</span></span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 2">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>printf(<span style="COLOR: maroon">"Impossible\n"</span>);</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes"><span style="mso-tab-count: 1">&nbsp;&nbsp;&nbsp;</span><span style="COLOR: blue">return</span> 0;</span></p>
<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt"><span style="FONT-SIZE: 14pt;  mso-hansi- mso-font-kerning: 0pt; mso-no-proof: yes">}</span></p>
<p> </p> <a href="http://hi.baidu.com/wuxyy/blog/item/6a484334229b414d251f1488.html">阅读全文</a>
		
		<br/><b>类别：</b><a href="http://hi.baidu.com/wuxyy/blog/category/Data%20Structures">Data Structures</a>&nbsp;<a href="http://hi.baidu.com/wuxyy/blog/item/6a484334229b414d251f1488.html#comment">查看评论</a>]]></description>
        <pubDate>2007-10-22  18:52</pubDate>
        <category><![CDATA[Data Structures]]></category>
        <author><![CDATA[wuxyy]]></author>
		<guid>http://hi.baidu.com/wuxyy/blog/item/6a484334229b414d251f1488.html</guid>
</item>

<item>
        <title><![CDATA[SRM 366]]></title>
        <link><![CDATA[http://hi.baidu.com/wuxyy/blog/item/0444b27e7fe9463b0cd7daa0.html]]></link>
        <description><![CDATA[
		
		<p><font size="2">宿舍网速太慢，最近一直上不去。昨晚终于能上了，做了SRM366.</font></p>
<p><font size="2">250pt是根据题目所给的规则排序，规则也不算很简单，所以写太久，只拿到180pt.</font></p>
<p><font size="2">500pt不难，一下就能看出可以用DP解决，看到不少挂了的程序是用dfs，显然会TLE.</font></p>
<p><font size="2">1000pt有些复杂，样例都可以用贪心得出来，但估计这题没这种容易，就直接放弃掉了。</font></p>
<p><font size="2">系统测试后，排Room 3，Div 51.</font></p>
<p><font size="2">Rating回升到1151，继续接近Div 1.</font></p> <a href="http://hi.baidu.com/wuxyy/blog/item/0444b27e7fe9463b0cd7daa0.html">阅读全文</a>
		
		<br/><b>类别：</b><a href="http://hi.baidu.com/wuxyy/blog/category/Topcoder">Topcoder</a>&nbsp;<a href="http://hi.baidu.com/wuxyy/blog/item/0444b27e7fe9463b0cd7daa0.html#comment">查看评论</a>]]></description>
        <pubDate>2007-09-19  10:38</pubDate>
        <category><![CDATA[Topcoder]]></category>
        <author><![CDATA[wuxyy]]></author>
		<guid>http://hi.baidu.com/wuxyy/blog/item/0444b27e7fe9463b0cd7daa0.html</guid>
</item>

<item>
        <title><![CDATA[2007 TCCC Algorithm Qualification]]></title>
        <link><![CDATA[http://hi.baidu.com/wuxyy/blog/item/f47060d0342d4a8da0ec9ced.html]]></link>
        <description><![CDATA[
		
		<p><font size="2">第一场，只水过最容易的第一题，做得又不是特别快，结果排到了600+，不得不参加第二场。</font></p>
<p><font size="2">晚上是第二场，显然大牛都在第一场过了，这场参数人数不过700+.</font></p>
<p><font size="2">第一题做到200+pt就能进550名内了。</font></p>
<p><font size="2">前两题都不难，过掉2题后，冲击第三题，不过还是没能在结束前调出来。</font></p>
<p><font size="2">系统测试后，排在217名，Rating回升了一点，继续在11xx徘徊。</font></p> 
		
		<br/><b>类别：</b><a href="http://hi.baidu.com/wuxyy/blog/category/Topcoder">Topcoder</a>&nbsp;<a href="http://hi.baidu.com/wuxyy/blog/item/f47060d0342d4a8da0ec9ced.html#comment">查看评论</a>]]></description>
        <pubDate>2007-08-21  21:44</pubDate>
        <category><![CDATA[Topcoder]]></category>
        <author><![CDATA[wuxyy]]></author>
		<guid>http://hi.baidu.com/wuxyy/blog/item/f47060d0342d4a8da0ec9ced.html</guid>
</item>

<item>
        <title><![CDATA[2007ACM/ICPC中国赛区竞赛日程]]></title>
        <link><![CDATA[http://hi.baidu.com/wuxyy/blog/item/ddc7f403d86165753812bb23.html]]></link>
        <description><![CDATA[
		
		<p><font size="2">南京赛区(NUAA) <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 网络预赛&nbsp;&nbsp;&nbsp;&nbsp; Sep&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 29, 2007 <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 现场决赛 Oct 26-28, 2007 </font></p>
<p><font size="2">长春赛区(JLU) <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 网络预赛 Oct&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 7, 2007 <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 现场决赛 Nov&nbsp;&nbsp;&nbsp;&nbsp; 4 - 5, 2007</font></p>
<p><font size="2">北京赛区(BUAA) <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 网络预赛 Oct&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 13, 2007 <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 现场决赛 Nov 10-11, 2007 <br>
<br>
成都赛区(XHU) <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 网络预赛 Oct&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 14, 2007 <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 现场决赛 Nov 16-17, 2007 </font></p> <a href="http://hi.baidu.com/wuxyy/blog/item/ddc7f403d86165753812bb23.html">阅读全文</a>
		
		<br/><b>类别：</b><a href="http://hi.baidu.com/wuxyy/blog/category/acm%26%2347%3Bicpc">acm&#47;icpc</a>&nbsp;<a href="http://hi.baidu.com/wuxyy/blog/item/ddc7f403d86165753812bb23.html#comment">查看评论</a>]]></description>
        <pubDate>2007-08-17  00:02</pubDate>
        <category><![CDATA[acm&#47;icpc]]></category>
        <author><![CDATA[wuxyy]]></author>
		<guid>http://hi.baidu.com/wuxyy/blog/item/ddc7f403d86165753812bb23.html</guid>
</item>

<item>
        <title><![CDATA[SRM 363]]></title>
        <link><![CDATA[http://hi.baidu.com/wuxyy/blog/item/ecde9c5196ceb12642a75bb3.html]]></link>
        <description><![CDATA[
		
		<p><font size="2">250pt是求时钟在镜子中显示的时间，要提交的时候就断线，浪费了不少时间。</font></p>
<p><font size="2">500pt和SGU130 Circle几乎一样，更巧的是，我做TC前刚好在做。于是我很快打好了Calalan数，可是我组合数不是用递推算，而是直接用公式先阶乘再除。因为没注意数据很大，造成了溢出，这是在比赛快结束的时候才发现的。于是我用Java直接在平台上打，这次我没有求Calalan数，而是用了递推，就不担心溢出了。</font></p>
<p><font size="2">Resubmit了500pt后，排名从16一下跌到了300.</font></p>
<p><font size="2">系统测试后，正如我所料，500pt fail掉一批人，我回升到 Div 2里159名，Room里5名，从而也避免了降Rating.</font></p>
<p><font size="2">SRM已经连续两次不算Rating了，这次数据终于没在出错了。</font></p> <a href="http://hi.baidu.com/wuxyy/blog/item/ecde9c5196ceb12642a75bb3.html">阅读全文</a>
		
		<br/><b>类别：</b><a href="http://hi.baidu.com/wuxyy/blog/category/Topcoder">Topcoder</a>&nbsp;<a href="http://hi.baidu.com/wuxyy/blog/item/ecde9c5196ceb12642a75bb3.html#comment">查看评论</a>]]></description>
        <pubDate>2007-08-12  10:49</pubDate>
        <category><![CDATA[Topcoder]]></category>
        <author><![CDATA[wuxyy]]></author>
		<guid>http://hi.baidu.com/wuxyy/blog/item/ecde9c5196ceb12642a75bb3.html</guid>
</item>

<item>
        <title><![CDATA[SRM 361 —— Room 3]]></title>
        <link><![CDATA[http://hi.baidu.com/wuxyy/blog/item/437d2a3411fba3395bb5f5de.html]]></link>
        <description><![CDATA[
		
		<p><font size="2">250pt，做得比较慢，得到180pt，还好AC了，不知道这题怎么fail掉那么多人。</font></p>
<p><font size="2">500pt，我想复杂了，几行代码就能解决的问题，我写复杂了，所以浪费了点时间，最后得到320pt.</font></p>
<p><font size="2">1000pt，不算难，不过又是没做完</font></p>
<p><font size="2">系统测试前，Div2里排135名，Room里排第5.</font></p>
<p><font size="2">测试结束后，升到Div2 39，Room 3.</font></p>
<p><font size="2">比Room 2少了12pt，大概也就是慢他几十秒。</font></p>
<p><font size="2">郁闷啊，就这样没了$20.</font></p>
<p><font size="2">Rating升到1176，就快升到div1了。</font></p> <a href="http://hi.baidu.com/wuxyy/blog/item/437d2a3411fba3395bb5f5de.html">阅读全文</a>
		
		<br/><b>类别：</b><a href="http://hi.baidu.com/wuxyy/blog/category/Topcoder">Topcoder</a>&nbsp;<a href="http://hi.baidu.com/wuxyy/blog/item/437d2a3411fba3395bb5f5de.html#comment">查看评论</a>]]></description>
        <pubDate>2007-08-02  11:04</pubDate>
        <category><![CDATA[Topcoder]]></category>
        <author><![CDATA[wuxyy]]></author>
		<guid>http://hi.baidu.com/wuxyy/blog/item/437d2a3411fba3395bb5f5de.html</guid>
</item>

<item>
        <title><![CDATA[C++之四书五经(下) (ZT)]]></title>
        <link><![CDATA[http://hi.baidu.com/wuxyy/blog/item/5c444b5484c35856574e005e.html]]></link>
        <description><![CDATA[
		
		<p><font size="2">我在上篇中“盘点”了TCPL和D&amp;E以及入门教程、高效和健壮编程、模板和泛型编程等方面共十几本C++好书。冬去春来，让我们继续C++书籍精彩之旅。</font></p>
<h4><font size="2">标准库</font></h4>
<p><font size="2">当我还在研究院工作时，与同院另外两家研究所合作开发过一个大型水利枢纽调度集成项目。我们三家软件系统之间都要相互通信。在调试通讯模块时，细心的客户（一名好学的系统管理员）发现对于同一通信规约的解释代码，我的不超过30行，而对方的则超过了150行且很难看懂。这位系统管理员很纳闷，我说大家编程风格和习惯不一样，我使用了标准库，而他使用了传统C编程风格以及他所习惯的另外一些技术。</font></p>
<p><font size="2">别误会！我绝无贬低这位合作伙伴的意思。事实上，我对那些真正有着深厚的C编程功力的程序员常常怀有钦佩之心。毕竟，C++能有今天的成功在很大程度上缘于它深深地植根于C。作为一名C++程序员，倘若不熟悉C++中的C，我往往会认为他的基本功是不扎实的，他的技术底气是不足的。</font></p>
<p><font size="2">不过话又说回来，C++是一种多范型（paradigm）编程语言，具体采用哪种编程风格，专业程序员应该知道视具体情况而定。作为一名经常需要在现场做即兴开发的项目负责人，为了短平快地解决当务之急，我习惯尽量采用现有的库（和组件）。效率（以及强健性）久经验证的C++标准库已经摆在那儿了，何乐而不用呢？</font></p>

<p align="center"><a href="http://www.amazon.com/gp/product/0201379260/104-3482654-8100756?SubscriptionId=1100889MK2XY9PSTV5G2&amp;n=283155" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image001.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/12513" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image001a.jpg" border="0"></font></a></p>
<h5 align="center">Nicolai M. Josuttis,《The C++ Standard Library: A Tutorial and Reference》<a href="http://www.amazon.com/gp/product/0201379260/104-3482654-8100756?SubscriptionId=1100889MK2XY9PSTV5G2&amp;n=283155" target="_blank">原文版</a>、<a href="http://www.dearbook.com.cn/book/12513" target="_blank">中文版：《<span>C++</span>标准程序库：自修教程与参考手册</a>》</h5>
<p><font size="2">这是一本百科全书式的C++标准库著作，是一本需要一再查阅的参考大全。它在完备性、细致性以及精确性方面都是无与伦比的。本书详细介绍了每一标准库组件的规格和用法，内容涵盖包括流和本地化在内的整个标准库而不仅仅是STL。正如本书副标题所示，它首先适合作为教程阅读，尔后又可用作参考手册。</font></p>
<p><font size="2">浅显易懂的写作风格使得这本书非常易读。如果你希望学习标准库的用法并尽可能地发挥其潜能，那你必须拥有这本书。正如网络上所言，这本书不仅仅应该摆在你的书橱中，更应该放到你的电脑桌上。我向每一位职业C++程序员强烈推荐。</font></p>
<p><font size="2"></font></p>
<p align="center"><a href="http://www.amazon.com/gp/product/0201183951/104-3482654-8100756?SubscriptionId=1100889MK2XY9PSTV5G2&amp;n=283155" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image002.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/13080" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image002a.jpg" border="0"></font></a></p>
<h5 align="center">Angelika Langer, Klaus Kreft,,《Standard C++ IOStreams and Locales: Advanced Programmer's Guide and Reference》<a href="http://www.amazon.com/gp/product/0201183951/104-3482654-8100756?SubscriptionId=1100889MK2XY9PSTV5G2&amp;n=283155" target="_blank">原文版</a>、<a href="http://www.dearbook.com.cn/book/13080" target="_blank">中文版《标准<span>C++</span>输入输出流与本地化》</a></h5>
<p><font size="2">C++标准库由STL、流和本地化三部分构成。关于STL的书市面上已经有不少，但罕见流和本地化方面的专著。本书是这两个领域中最优秀的一本，迄今为止没有任何一本书比这一本更全面详尽地讨论了流和本地化。如果你不满足于停留在“会用”流库的层面，千万不要错过它。</font></p>
<p><font size="2">2001年夏天，我草草翻阅过这本书的中文版，从内容到包装都给我留下了比较深刻的印象——不过负面的居多一些。2003年秋天，无意中得知某网络书店正以超低价格甩卖这本书的中译本，情不自禁，一阵唏嘘。</font></p>
<p><font size="2"></font></p>
<p align="center"><a href="http://www.dearbook.com.cn/book/ViewBook.aspx?pno=TS007016" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image003.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/viewbook.aspx?pno=TS00104893" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image004a.jpg" border="0"></font></a></p>
<h5 align="center">Scott Meyers,《Effective STL》<a href="http://www.dearbook.com.cn/book/ViewBook.aspx?pno=TS007016" target="_blank">影印版</a>、<a href="http://www.dearbook.com.cn/book/viewbook.aspx?pno=TS00104893" target="_blank">中文版</a></h5>
<p><font size="2">读完Scott 的《Effective C++》和《More Effective C++》的中译本之后，我一直期待这本书的中文版。我从潘爱民先生的个人主页上了解到，他和他的合作伙伴似乎早已完成了这本书的翻译工作，可惜至今市面上仍不得见。幸运的是，我们可以看到它的原版。</font></p>
<p><font size="2">本书是使用STL的程序员必读之作。在这本书中，Scott向我们讲述STL容器和算法的工作机制以及如何以最佳方式使用它们。和Scott的其他作品一样，这本书的写作风格清晰、精确，具有极佳的可读性。看过这本书以后，我想你也许会和我以及其他C++程序员一样产生这样的想法：Scott什么时候会写出一本“More Effective STL”？</font></p>

<p align="center"><a href="http://www.dearbook.com.cn/book/12467" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image004.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/12548" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image004a.jpg" border="0"></font></a></p>
<h5 align="center"><span>Matthew H. Austern</span>,《<span>Generic Programming and the STL: Using and Extending the C++ Standard Template Library</span>》<a href="http://www.dearbook.com.cn/book/12467" target="_blank">影印版</a>、<a href="http://www.dearbook.com.cn/book/12548" target="_blank">中文版《泛型编程与STL》</a></h5>
<p><font size="2">关于STL，我还提醒你留心Matthew H. Austern的《Generic Programming and the STL: Using and Extending the C++ Standard Template Library》（《泛型编程与STL》，中国电力出版社）。这本书散发着浓厚的学院气息。Andrew Koenig和Barbara Moo在《Accelerated C++: Practical Programming by Example》一书末尾郑重推荐另外两本进阶好书（除了他们自己的《Ruminations on C++》外），其中一本是TCPL，另外一本就是本书！</font></p>
<h4><font size="2">网络编程</font></h4>
<p><font size="2">在网络编程时代，C++应该扮演着怎样的角色，让ACE（Adaptive Communications Environment）来告诉你。</font></p>

<p align="center"><a href="http://www.dearbook.com.cn/book/20630" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image0051.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/viewbook.aspx?pno=TS0021400" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image0052.jpg" border="0"></font></a></p>
<h5 align="center">Douglas C. Schmidt, Stephen D. Huston,《C++ Network Programming》<a href="http://www.dearbook.com.cn/book/20630" target="_blank">Volume 1: Mastering Complexity with ACE and Patterns</a>、<a href="http://www.dearbook.com.cn/book/viewbook.aspx?pno=TS0021400" target="_blank">Volume 2: Systematic Reuse with ACE and Frameworks</a></h5>
<p><font size="2"></font></p>
<p align="center"><a href="http://www.dearbook.com.cn/book/20664" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image0061.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/13040" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image0062.jpg" border="0"></font></a></p>
<h5 align="center">中文版：,《C++网络编程》<a href="http://www.dearbook.com.cn/book/20664" target="_blank">卷1：运用ACE和模式消除复杂性</a>、<a href="http://www.dearbook.com.cn/book/13040" target="_blank">卷2：基于 ACE 和框架的系统化复用</a></h5>
<p><font size="2">采用C++进行企业级网络编程，目前ACE（以及这两本书）是一个值得考虑的选择。ACE是一个面向对象、跨平台、开放源码的网络编程框架，目标在于构建高性能网络应用和中间件。Douglas是ACE的创始人，Stephen则已为ACE提供了数年的技术支持和顾问服务，两位都是ACE社群（是的，ACE的影响和实际应用的程度已经形成了一个社群）的专家。</font></p>
<p><font size="2">ACE并不单单被大学和研究所追捧，它已经被成功地应用于世界上成千上万个商业应用中。在电信、宇航、医药和财经领域的网络系统中，ACE已经并继续发挥着重要的作用。如果你准备开发高性能通讯系统，你应该考虑考虑这一汇集世界顶尖专家智慧的成果。</font></p>
<p><font size="2">除了使用C++面向对象设计技术和模板等高级语言特性外，ACE还运用了大量的模式。《C++网络编程》卷1和卷2并不仅仅教你关于ACE的方方面面，它还会教给你模式和通用框架设计等高级技术等。所以，作为一名中、高级C++程序员，即使你很少进行正儿八经的C++网络程序设计，阅读这两本书同样可以从中受益。</font></p>
<p><font size="2">是的，并非所有网络应用都要使用Web服务器（以及其他应用服务器）和重量级组件模型，换个思路，它们或许也可以从轻量级的ACE组件中获益。</font></p>
<h4><font size="2">杂项</font></h4>
<p><font size="2">以下几本书所以被列入“杂项”单元，是因为我没有考虑到合适的归类方法，它们和上面的书籍一样，值得一读。</font></p>

<p align="center"><a href="http://www.dearbook.com.cn/book/12738" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image0071.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/31587" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image0072.jpg" border="0"></font></a></p>
<h5 align="center">Bruce Eckel,《Thinking in C++》影印版<a href="http://www.dearbook.com.cn/book/12738" target="_blank">二版</a>、<a href="http://www.dearbook.com.cn/book/31587" target="_blank">三版（又名卷二）</a></h5>
<p><font size="2"></font></p>
<p align="center"><a href="http://www.dearbook.com.cn/book/63079" target="_blank"><font size="2"><img hspace="15" src="http://book.csdn.net/BookFiles/69/05/image0080.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/12737" target="_blank"><font size="2"><img hspace="15" src="http://book.csdn.net/BookFiles/69/05/image0081.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/58611" target="_blank"><font size="2"><img hspace="15" src="http://book.csdn.net/BookFiles/69/05/image0082.jpg" border="0"></font></a></p>
<h5 align="center">中文《C++编程思想》<a href="http://www.dearbook.com.cn/book/63079" target="_blank">二版</a>、<a href="http://www.dearbook.com.cn/book/12737" target="_blank">卷一：标准C++导引</a> <a href="http://www.dearbook.com.cn/book/58611" target="_blank">卷二：实用编程技术</a></h5>
<p><font size="2">《Thinking in C++》的第1版于1996年荣获“软件研发”杂志评选的图书震撼大奖。最新推出的第2版对内容进行了大幅改写和调整，以反映C++标准化带来的影响以及近几年面向对象领域最新研究和实践成果。“输入输入流”、“多重继承”、“异常处理”和“运行时类型识别”等高级主题连同C++标准化以后增加的一些内容则被放入第二卷中。Bruce是一名经验丰富的C++讲师和顾问，其培训和写作经验都是世界一流水准，他的作品比那些“玩票”的技术人员写的东西更能吸引读者。事实上，在同类图书中，对于大多数读者而言，这本书的可读性要超过TCPL和《C++ Primer》。顺带一提，访问作者的站点，你可以先睹第二卷的风采。</font></p>

<p align="center"><a href="http://www.amazon.com/gp/product/0201423391/104-3482654-8100756?SubscriptionId=1100889MK2XY9PSTV5G2&amp;n=283155" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image009.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/7210" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image009a.jpg" border="0"></font></a></p>
<h5 align="center">Andrew Koenig, Barbara E. Moo,,《Ruminations on C++: A Decade of Programming Insight and Experience》<a href="http://www.amazon.com/gp/product/0201423391/104-3482654-8100756?SubscriptionId=1100889MK2XY9PSTV5G2&amp;n=283155" target="_blank">原版</a>、<a href="http://www.dearbook.com.cn/book/7210" target="_blank">中文版《C++沉思录》</a></h5>
<p><font size="2">Andrew是世界上屈指可数的C++专家。这是一本关于C++编程思想和程序设计技术而非语言细节的著作。如果你已经具有一定的基础，这本书将教你在进行C++编程时应该怎样思考，应该如何表达解决方案。整本书技术表达透彻，文字通俗易懂。Bjarne这样评价这本书：本书遍布“C++是什么、C ++能够做什么”的真知灼见。</font></p>

<p align="center"><a href="http://www.dearbook.com.cn/book/10422" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image0010.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/5630" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image0010a.jpg" border="0"></font></a></p>
<h5 align="center">Stanley B. Lippman,《Inside The C++ Object Model》<a href="http://www.dearbook.com.cn/book/10422" target="_blank">影印版</a>、<a href="http://www.dearbook.com.cn/book/5630" target="_blank">中文版《深度探索C++对象模型》</a></h5>
<p><font size="2">从编译器的角度观察C++可以使你知其然并知其所以然。本书探讨了大量的C++面向对象程序设计的底层运作机制，包括构造函数、函数、临时对象、继承、虚拟、模板的实例化、异常处理、运行期类型识别等，另外还介绍了一些在实现C++对象模型过程中做出的权衡折衷。喜欢刨根问底的C++程序员不要错过这本书。</font></p>
<p><font size="2">Erich Gamma, Richard Helm, Ralph Johnson, John Vlissides, Design Patterns: Elements of Reusable Object-Oriented software</font></p>

<p align="center"><a href="http://www.dearbook.com.cn/book/31081" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image0011.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/12305" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image0011a.jpg" border="0"></font></a></p>
<h5 align="center">Erich Gamma, Richard Helm, Ralph Johnson, John Vlissides,《Design Patterns: Elements of Reusable Object-Oriented software》<a href="http://www.dearbook.com.cn/book/31081" target="_blank">影印版</a>、<a href="http://www.dearbook.com.cn/book/12305" target="_blank">中文版《设计模式：可复用面向对象软件的基础》</a></h5>
<p><font size="2">设计可复用的面向对象的软件，你需要掌握设计模式。本书并非专为C++程序员而写，但它采用了C++（以及Smalltalk）作为主要示例语言， C++程序员尤其易于从中受益。四位作者都是国际公认的面向对象软件领域专家，他们将面向对象软件的设计经验作为设计模式详细记录下来。这本书影响是如此深远，以至于四位作者以及本书都被昵称为GoF（Gang of Four）。本书学院气息浓厚，行文风格严谨简洁，虽然它不如某些讲解模式的书籍易读，但真正要精准地理解设计模式，本书是终极权威。学习设计模式，这本书需要一而再、再而三的咀嚼。顺带一句：请将设计模式化作开拓思维的钥匙，切莫成为封闭思维的枷锁。</font></p>

<p align="center"><a href="http://www.dearbook.com.cn/book/2559" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image0012a.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/12635" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/05/image0013a.jpg" border="0"></font></a></p>
<h5 align="center">John Lakos,《Large-Scale C++ Software Design》<a href="http://www.dearbook.com.cn/book/2559" target="_blank">中文版《大规模C++程序设计》</a>、<a href="http://www.dearbook.com.cn/book/12635" target="_blank">候捷：《STL 源码剖析》</a></h5>
<p><font size="2">还有一些C++好书值得一读，恕此处无法一一列出。例如John Lakos的著作《Large-Scale C++ Software Design》（《大规模C++程序设计》，中国电力出版社）和侯捷先生的《STL 源码剖析》（华中科技大学出版社）等。</font></p>
<p><font size="2">《STL 源码剖析》是一本很有特色的书，但我认为它还可以更好。我个人期待侯捷先生自第一版发行以来经过对模板技术的沉淀和再思考之后，再写一本剖析得更深入、更透彻并且更全面的“第二版”。遗憾的是，侯捷先生在完成《C++ Templates: The Complete Guide》一书的翻译后似乎决定暂时告别模板、泛型编程和STL领域。</font></p>
<p><font size="2">使用C++成功开发大规模软件系统，不仅需要很好地理解大多数C++书籍中讲述的逻辑设计问题，更需要掌握《大规模C++程序设计》中讲述的物理设计技术。当然，这本书的确有点过时了，不过，如果你的精力和金钱都比较宽绰，买一本看看并无坏处。</font></p>
<p><font size="2">至此，我想有必要声明一下，有一些（好）书没有得到推荐，主要原因如下：</font></p>
<ul>
<li><font size="2">以上这些书已经足够多、足够好了。 </font></li>
    <li><font size="2">我不会推荐通过正常渠道很难购买到的书籍 ——不管是中文版还是英文版。 </font></li>
    <li><font size="2">作（译）者名气大小不影响我的推荐。我们是在看书，不是看人。 </font></li>
    <li><font size="2">我不会推荐我从来没有看过的书。我至少要看过其中的某个版本（包括电子档）。这个“看”，一般指“认真阅读”，不过有一些也只能算是“浏览”。 </font></li>
</ul>
    <h4><font size="2">结语</font></h4>
    <p><font size="2">作为一名普通技术写译者，我深知技术创作和翻译的艰辛（和快乐），并多多少少了解一些有关技术书籍创作、翻译、制作、出版以及市场推介背后的细节。今天，我不会再对一本看上去差强人意的图书信口开河。罗列同一本书的各种版本的用意只在于为你多提供一些信息，让你多一种选择。</font></p>
    <p><font size="2">在本文成文的后期，我给Bjarne写了一封信，请教如果他来写这篇文章会怎么写。他给了我简明扼要的建议。在肯定以上列出的绝大部分图书都是世界顶尖水平的C++著作的同时，Bjarne提醒我别忘了向专家级程序员推荐《The C++ Standard : Incorporating Technical Corrigendum No. 1》 </font></p>
    <p align="center"><a href="http://www.amazon.com/gp/product/0470846747/104-3482654-8100756?SubscriptionId=1100889MK2XY9PSTV5G2&amp;n=283155" target="_blank"><font size="2"><img src="http://book.csdn.net/BookFiles/69/05/image0014.jpg" border="0"></font></a></p>
    <p align="center"><a href="http://www.amazon.com/gp/product/0470846747/104-3482654-8100756?SubscriptionId=1100889MK2XY9PSTV5G2&amp;n=283155" target="_blank"><font size="2">《The C++ Standard : Incorporating Technical Corrigendum No. 1》</font></a></p>
    <p><font size="2">Bjarne还友好地提醒我，在我的推荐列表中没有哪一本有助于C++程序员进行Windows编程——这正是我的本意。在这篇文章中，我只推荐、点评平台中立的C++著作（网络编程除外）——和操作系统无关，和集成开发环境无关，我甚至幻想它们和编译器也无关。你可以根据业务开发需要，选读自己喜爱的领域相关的C++书籍。</font></p>
    <p><font size="2">说到“系统无关、平台中立”，我不由得想起了“抽象层”的概念。开发实际应用的C++程序员通常工作于特定操作系统、特定开发环境和特定业务领域之中，而对标准C++和C++标准库扎实而深刻的把握，无疑是你得以在不同的操作系统、不同的开发环境以及不同的业务领域之间纵横驰骋的“抽象”本钱。</font></p> <a href="http://hi.baidu.com/wuxyy/blog/item/5c444b5484c35856574e005e.html">阅读全文</a>
		
		<br/><b>类别：</b><a href="http://hi.baidu.com/wuxyy/blog/category/c%26%2347%3Bc%2B%2B">c&#47;c++</a>&nbsp;<a href="http://hi.baidu.com/wuxyy/blog/item/5c444b5484c35856574e005e.html#comment">查看评论</a>]]></description>
        <pubDate>2007-07-25  10:37</pubDate>
        <category><![CDATA[c&#47;c++]]></category>
        <author><![CDATA[wuxyy]]></author>
		<guid>http://hi.baidu.com/wuxyy/blog/item/5c444b5484c35856574e005e.html</guid>
</item>

<item>
        <title><![CDATA[C++之四书五经(上) (ZT)]]></title>
        <link><![CDATA[http://hi.baidu.com/wuxyy/blog/item/a719271f311554caa686695d.html]]></link>
        <description><![CDATA[
		
		<p><font size="2">C++是一门广泛用于工业软件研发的大型语言。它自身的复杂性和解决现实问题的能力，使其极具学术研究价值和工业价值。和C语言一样，C++已经在许多重要的领域大获成功。</font></p>
<p><font size="2">然而，一个不可否认的现实是，在低阶程序设计领域，C++挤压着C同时也在承受着C的强烈反弹，而在高阶程序设计领域，Java和C#正在不断蚕食着C++的地盘。也许C++与C合为一体永远都是一个梦想，也许Java和C#的狂潮终将迫使C++回归本位——回到它有着根本性优势的开发领域：低级系统程序设计、高级大规模高性能应用设计、嵌入式程序设计以及数值科学计算等。果真如此，我认为这未尝不是一件好事。</font></p>
<p><font size="2">C++吸引如此之多的智力投入，以至于这个领域的优秀作品，包括重量级的软件产品、程序库以及书籍等，数不胜数。文题“C++程序设计之四书五经” 一个不太严格的含义是：C++程序设计之四书×五经。是的，在本文（及其下篇）中，我将分门别类推荐20多本C++好书，你可以根据自己的需要选读。</font></p>
<h3><font size="2">TCPL和D&amp;E</font></h3>
<p><font size="2">TCPL和D&amp;E分别是《The C++ Programming Language》和《The Design and Evolution of C++》的简称，均出自Bjarne Stroustrup之手。我将它们单列出来，首先是因为Bjarne是C++语言的创建者，然后是因为比“首先”那个原因更重要的原因：这两本书是C+ +领域毋庸置疑的杰作。说它们是C++语言圣经，并不为过。</font></p>
<p align="center"><a href="http://www.dearbook.com.cn/book/5577" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image001.jpg" border="0"></font></a><a href="http://www.dearbook.com/book/30980" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image001a.jpg" border="0"></font></a></p>
<h5 align="center"><a href="http://www.research.att.com/%7Ebs/" target="_blank"><font color="#000080">Bjarne Stroustrup</font></a>,《C++程序设计语言》<a href="http://www.dearbook.com.cn/book/5577" target="_blank"><font color="#000080">影印版</font></a>、<a href="http://www.dearbook.com/book/30980" target="_blank"><font color="#000080">中文版</font></a>、<a href="http://www.dearbook.com.cn/book/5292" target="_blank"><font color="#000080">题解</font></a></h5>
<p><font size="2">迄今为止，TCPL是除了C++标准文献之外最权威的C++参考手册。和大多数人的看法不大一样，我认为Bjarne的文字语言并不逊色于他所创建的程序语言，至少我喜欢这种学院气息浓厚的作品。本书对C++语言的描述轮廓鲜明、直截了当。它从C++语言创建者的角度来观察C++，这是任何别的作者和书籍做不到的——没有任何人比Bjarne自己更清楚该怎么来使用C++。</font></p>
<p><font size="2">这是一本严肃的著作，以中、高级C++开发人员为目标读者。如果你是一名有经验的C++程序员，需要了解更加本质的C++知识，本书正是为你而写。它不是那种让你看了会不断窃喜的小书，需要用心体会，反复咀嚼。在阅读过程中，请特别留心Bjarne先生强调了什么，又对什么一语带过。我个人比较喜欢这本书的第四部分“使用C++做设计”，这样的内容在类似的程序设计语言书籍中很难看到——我甚至认为Bjarne应该将这部分独立出来单独写一本书。</font></p>
<p align="center"><a href="http://www.dearbook.com.cn/Book/ViewBook.aspx?pno=TS0012478" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image002.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/11768" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image002a.jpg" border="0"></font></a></p>
<h5 align="center"><a href="http://www.research.att.com/%7Ebs/" target="_blank"><font color="#000080">Bjarne Stroustrup</font></a>,《C++语言的设计和演化》<a href="http://www.dearbook.com.cn/Book/ViewBook.aspx?pno=TS0012478" target="_blank"><font color="#000080">影印版</font></a>、<a href="http://www.dearbook.com.cn/book/11768" target="_blank"><font color="#000080">中文版</font></a></h5>
<p><font size="2">D&amp;E是一本关于C++语言设计原理、设计决策和设计哲学的专著。它清晰地回答了C++为什么会成为今天这个样子而没有变成另外一种语言。作为C++语言的创建者，Bjarne淋漓尽致地展示了他独到而深刻的见解。除了广受赞誉的语言特性外，Bjarne没有回避那些引起争议的甚至被拒绝的 C++特性，他一一给出了逻辑严密、令人信服的解释。内容涵盖C++的史前时代、带类的C、C++的设计规则、标准化、库、内存管理、多重继承、模板等，对包括异常机制、运行时类型信息和名字空间在内的重要的新特性都分别进行了深入探讨。每一名C++程序员都应该可以从Bjarne的阐释中加深对手中这门语言的认识。</font></p>
<p><font size="2">需要再次提醒的是，这两本书知识浓缩，信息量极大，请不要错过Bjarne每一句看似漫不经意的话。</font></p>
<h3><font size="2">入门教程</font></h3>
<p><font size="2">学习任何一门语言都需要一个从入门到精通、从新手到高手循序渐进的过程。不过，对于一个所谓的新手而言，究竟是一个完完全全的新手，还是一个熟悉某种别的语言的“新手”，甚至是在某种语言程序设计领域已经颇有建树的高手，很难一概而论？不同的C++新手需要不同的入门书籍。</font></p>
<p align="center"><a href="http://www.dearbook.com.cn/2006/ec++/index.htm" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image003.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/13190" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image003a.jpg" border="0"></font></a></p>
<h5 align="center"><a href="http://www.acceleratedcpp.com/authors/koenig/" target="_blank"><font color="#000080">Andrew Koenig</font></a>, <a href="http://www.acceleratedcpp.com/authors/moo/index.html" target="_blank"><font color="#000080">Barbara E. Moo</font></a>,《Accelerated C++》<a href="http://www.dearbook.com.cn/2006/ec++/index.htm" target="_blank"><font color="#000080">影印版</font></a>、<a href="http://www.dearbook.com.cn/book/13190" target="_blank"><font color="#000080">中文版</font></a></h5>
<p><font size="2">和市面上大多数C++教程不同，本书不是从“C++中的C”开始讲解，而是始于地道的C++特性。从一开始就使用标准库来写程序，随着讲述的逐渐深入，又一一解释这些标准库组件所依赖的基础概念。另外，和其他C++教材不同的是，这本书以实例拉动语言和标准库的讲解，对后两者的讲解是为了给实例程序提供支持，而不是像绝大多数C++教材那样，例子只是用作演示语言特性和标准库用法的辅助工具。</font></p>
<p><font size="2">作者在C++领域的编程实践、教育培训以及技术写作方面都是世界一流水准。我喜欢这种大量使用标准库和C++语言原生特性的清新的写作风格。在这本教材面前，几乎迄今为止的所有C++教材都黯然失色或显得过时。尽管这本教材也许对于国内的高校教育来说有些前卫，不过我仍然极力向我的同行们推荐。顺带一提，在Bjarne和我最近的一封通信里，他这样评价本书:对于有经验的程序员学习C++而言，这本书可能是世界上最好的一本。</font></p>
<p align="center"><a href="http://www.dearbook.com.cn/book/63108" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image004.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/92394" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image004a.jpg" border="0"></font></a></p>
<h5 align="center">Stanley B.Lippman, Josee Lajoie,《C++ Primer》<a href="http://www.dearbook.com.cn/book/63108" target="_blank"><font color="#000080">影印第三版</font></a>、<a href="http://www.dearbook.com.cn/book/92394" target="_blank"><font color="#000080">中文第四版</font></a></h5>
<p><font size="2">这本书的名字多少有点让人误解。尽管作者声称这本书是为C++新手而写，但无论是它的厚度还是讲解的深度都暴露了似乎并非如此。也许说它是一本“从入门到精通”的C++教程会更合适一些。我个人认为它并不适合完全不懂C++的初学者——在阅读这本书之前，你至少应该先有那么一点C或C++的背景知识，或者至少要具有一些其他语言的编程经验。</font></p>
<p><font size="2">尽管这本书省略了一些高级C++特性的讨论，但仍然可以称得上是迄今为止最全面的C++学习教程。事实上，如果一名C++初学者能够扎扎实实地读完本书并对照《C++ Primer Answer Book》完成全部习题的话，他的水平肯定可以进入职业C++程序员的行列。我个人认为，即使你已经拥有了TCPL，这本书依然有拥有的价值，因为在许多方面它比TCPL来得更详细、更易懂。</font></p>
<p align="center"><a href="http://www.dearbook.com.cn/Book/ViewBook.aspx?pno=TS004278" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image005.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/viewbook.aspx?pno=TS008083" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image005a.jpg" border="0"></font></a></p>
<h5 align="center">Stanley B. Lippman,《Essential C++》<a href="http://www.dearbook.com.cn/Book/ViewBook.aspx?pno=TS004278" target="_blank"><font color="#000080">影印版</font></a>、<a href="http://www.dearbook.com.cn/book/viewbook.aspx?pno=TS008083" target="_blank"><font color="#000080">候捷译文版</font></a></h5>
<p><font size="2">可以不太严格地认为这本书是《C++ Primer》的精简版。本书一一讲述了C++中最具代表性的主题，包括过程式编程、泛型编程、基于对象编程、面向对象编程、模板编程以及异常处理等。 Stanley将门槛调低到“具有其他语言程序设计经验”的C++新手所能接受的最基本的层次，使他们能够迅速开始使用C++编程而又免于阅读《C++ Primer》那样的大部头。它以实例引导学习，力图使读者在最短的时间内把握C++的精粹。</font></p>
<p><font size="2">也许换一个人来概述C++编程范型（paradigm）的方方面面需要好几百页才能说清楚，但这本小书不可思议地做到了这一点。我个人非常喜欢这种满是技术、简明扼要并且“有话好好说”的书。这本书同样具有一个明显的风格：所有程序例子全部采用标准库组件，让人耳目一新。</font></p>
<p><font size="2">以上三本书都不是为了完完全全的编程新手而写。完全的C++编程新手可以阅读Francis Glassborow的新书（尚未出版）：《A Beginners Introduction to Computer Programming: You Can Do It!》。这也是Bjarne的推荐。Francis Glassborow是ACCU主席，多年来他对几乎每一本C++经典名著评头论足，他自己的这一本自然会引起C++社群的极大兴趣。</font></p>
<h3><font size="2">高效、健壮编程</font></h3>
<p><font size="2">两年前我在负责一个省级电力调度系统项目时编写了一个网关程序，它从SCADA系统获取电力实时信息。通讯接口采用了不常用的数据库直连方式（这个网关程序一端连接SQL Server 6.5，另一端连接Oralce 8.1.6）。由于实时测点近万，每次将全部取样更新或插入一遍显然是低效的。我在网关程序里建了一个内存库，获取到的数据首先在其中进行比较，然后决定是否更新物理数据库（同时还做了别的更复杂的事情……），从而在效率和资源占用两方面达到了预期效果。</font></p>
<p><font size="2">这个程序一直运行得很好，但在离开现场之后的某一天，系统管理员打来电话，说大概因为网络故障等原因，有时这个网关程序会崩溃掉——它自己崩掉也就罢了，问题是它还会把Windows 2000 Advanced Server搞成“蓝屏”！（坦白地说，我还从来没看过哪个非蓄意的程序有这个“能耐”）由于当时正忙于另外一个大项目，无法去现场调试，最后只有凭经验对内存库代码小心翼翼地封装以异常处理代码（同时也做了一些别的修改。这个程序本来不乏异常处理，可惜在开发调试期，很难模拟出真实的“异常”状况，以便验证那些异常处理代码真的可以工作）。这样，虽然没有彻底解决问题，但程序终究不再死得那么难看了。</font></p>
<p><font size="2">在这儿讲这么一段花絮有什么意思呢（当初为那个可怕的bug朝思暮想时我可不认为这是一个“花絮”）？我想说的是，对于任何软件而言，离开强健，效率也就无从谈起。而对于C++程序员来说，也许编写一个高效的程序并不难，但要编写一个需要7×24小时持续运行的服务端软件就不是那么容易了（实际上，只要应用服务器不当机，即使发生网络故障，即使数据库服务器当掉，那个网关程序也应该有能力持续运行下去），需要考虑许多因素，有时这些因素甚至远远超出 C++语言和开发工具的本身。作为一名开发实际项目软件的程序员，并非非得自己碰钉子才能积累经验，只要我们足够虚心，别人的经验往往都是我们很好的借鉴。鉴于此，我推荐以下几本书供你选读，它们可以让你从强健和效率两方面受益（当然了，它们涵盖的内容远不限于异常处理）。</font></p>
<p align="center"><a href="http://www.dearbook.com.cn/book/90971" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image006.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/110047" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image006a.jpg" border="0"></font></a></p>
<h5 align="center"><a href="http://www.aristeia.com/" target="_blank"><font color="#000080">Scott Meyers</font></a>,《Effective C++》英文原版<a href="http://www.dearbook.com.cn/book/9966" target="_blank"><font color="#000080">（二版</font></a>、<a href="http://www.dearbook.com.cn/book/90971" target="_blank"><font color="#000080">三版</font></a>），候捷中文版（<a href="http://www.dearbook.com.cn/book/8612" target="_blank"><font color="#000080">二版</font></a>、<a href="http://www.dearbook.com.cn/book/110047" target="_blank"><font color="#000080">三版</font></a>）</h5>
<p align="center"><a href="http://www.dearbook.com.cn/book/108458" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image007.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/4841" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image007a.jpg" border="0"></font></a></p>
<h5 align="center"><a href="http://www.aristeia.com/" target="_blank"><font color="#000080">Scott Meyers</font></a>,《More Effective C++》<a href="http://www.dearbook.com.cn/book/108458" target="_blank"><font color="#000080">英文原版</font></a>、<a href="http://www.dearbook.com.cn/book/4841" target="_blank"><font color="#000080">候捷中文版</font></a></h5>
<p><font size="2">如果说《Effective C++》主要讨论C++中一些相对基础的概念和技巧的话，那么《More Effective C++》则着重探讨了包括异常处理在内的一系列高级技术。与前者相比，后者具有两大主要区别:其一，它包含很多时新的标准C++的内容；第二，它讨论的主题倾向于“战略化”而非“战术化”，并且讨论得更深入、更彻底。尤其是对虚析构函数、智能指针、引用计数以及代理类（proxy classe）等技术和模式论述的深入程度，让人很难想象是出现于这样的一本小书之中。</font></p>
<p><font size="2">游刃有余的技术，高超的写作技巧，Scott无疑是世界上最优秀的C++技术作家之一。在简洁、清晰、易读等方面，这两本书都卓尔不群。总之， Scott提供的这85个可以改善编程技术和设计思维的方法，都是中、高级C++程序员必备的技能。我强烈推荐这两本书（实际上还有一本，稍后就会看到）。</font></p>
<p align="center"><a href="http://www.dearbook.com.cn/book/104756" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image008.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/viewbook.aspx?pno=TS009024" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image008a.jpg" border="0"></font></a></p>
<h5 align="center"><a href="http://www.gotw.ca/" target="_blank"><font color="#000080">Herb Sutter</font></a>,《Exceptional C++》<a href="http://www.dearbook.com.cn/book/104756" target="_blank"><font color="#000080">英文版</font></a>、<a href="http://www.dearbook.com.cn/book/viewbook.aspx?pno=TS009024" target="_blank"><font color="#000080">中文版</font></a></h5>
<p align="center"><a href="http://www.dearbook.com.cn/book/104758" target="_blank"><font color="#000080" size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image009.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/11693" target="_blank"><font color="#000080" size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image009a.jpg" border="0"></font></a></p>
<h5 align="center"><a href="http://www.gotw.ca/" target="_self"><font color="#000080">Herb Sutter</font></a>,《More Exceptional C++中文版》<a href="http://www.dearbook.com.cn/book/104758" target="_blank"><font color="#000080">英文版</font></a>、<a href="http://www.dearbook.com.cn/book/11693" target="_blank"><font color="#000080">中文版</font></a></h5>
<p><font size="2">你自认为是一名C++语言专家吗？读一读ISO C++标准委员会秘书长的这两本书再回答。在这两本书中，Herb采用了“问答”的方式指导你学习C++语言特性。对于每一个专题，Herb首先合理地设想出你的疑问和困惑，接着又猜测出你十有八九是错误的解答，然后给你以指点并提出最佳解决方案，最后还归纳出解决类似问题的普适性原则。</font></p>
<p><font size="2">这两本书是典型的深究C++语言细节的著作，很薄，但内容密集，远远超过Scott的那两本书，读起来很费脑筋 — 我个人认为它们要比Scott的书难懂得多。若要研习这薄薄的两本书所包含的知识，至少需要花费数月的时间！（在Scott的荐序中，他坦陈不止一次陷入 GotW问题的陷阱，你应该知道这意味着什么）对于语言细节的深究有什么好处呢？尽管在大多数情况下，我们不必关心C++代码幕后的动作，然而当我们不得不关心时，这两本书可以为我们提供很好的线索，因为它们揭示了C++语言中微妙而又至关重要的东西。</font></p>
<p align="center"><a href="http://www.dearbook.com.cn/book/11016" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image0010a.jpg" border="0"></font></a></p>
<h5 align="center">Stephen C. Dewhurst,<a href="http://www.dearbook.com.cn/book/11016" target="_blank"><font color="#000080">《C++程序设计陷阱》</font></a>，中国青年出版社</h5>
<p><font size="2">Stephen的理论素养和实践经验注定这是一本值得一读的好书。Stephen曾经是贝尔实验室中第一批C++使用者。他已经使用C++成功解决了包括编译器、证券交易、电子商务以及嵌入式系统等领域中的问题。本书汇集了作者来自开发一线的99条编程真知灼见，洞悉它们，你可以避免几乎所有常见的 C++设计和编程问题。</font></p>
<p><font size="2">我甚至认为，对于C++编程菜鸟而言，阅读这本书会比阅读Scott和Herb的书更能轻松而立竿见影地获得更大的提高。我个人很喜欢这本书的写作风格——Stephen的许多观点看似极端却无可辩驳。当然了，这种自信（以及冷幽默）来自于作者深厚的技术素养，而非自大的偏执。</font></p>
<p><font size="2">除了上面推荐的书籍外，Dov Bulka和 David Mayhew合著的《Efficient C++: Performance Programming Techniques》（《提高C++性能的编程技术》，清华大学出版社）也值得一看。这本超薄小书聚焦于高性能C++应用程序开发。两位作者都是IBM 软件专家，都工作于对性能要求极高的系统构建领域，本书是他们的经验之谈。也有人不喜欢这本书，因为它花了不少的篇幅讲述和C++无关的东西，我却恰恰因为这一点而对这本书产生好感，正是这些东西让我开阔了眼界。</font></p>
<h3><font size="2">模板和泛型编程</font></h3>
<p><font size="2">模板和基于模板的泛型编程无疑是当今发展最活跃的C++程序设计技术。模板的第一个革命性的应用是STL，它将模板技术在泛型容器和算法领域的运用展现得淋漓尽致，而Boost、Loki等现代程序库则将模板技术的潜能不断发挥到极致。在模板和泛型编程领域，我推荐以下两本重量级著作。</font></p>
<p align="center"><a href="http://www.dearbook.com.cn/book/21090" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image0011.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/viewbook.aspx?pno=TS0012965" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image0011a.jpg" border="0"></font></a></p>
<h5 align="center">David Vandevoorde, Nicolai M. Josuttis,《C++ Templates》<a href="http://www.dearbook.com.cn/book/21090" target="_blank"><font color="#000080">影印版</font></a>、<a href="http://www.dearbook.com.cn/book/viewbook.aspx?pno=TS0012965" target="_blank"><font color="#000080">中文版</font></a></h5>
<p><font size="2">有一种老套的赞美一本书的手法，大致是“没有看过这本书，你就怎么怎么地”，这里面往往夸张的成分居多。不过，倘若说“没有看过《C++ Templates: The Complete Guide》，你就不可能精通C++模板编程”，那么这个论断对于世界上绝大多数C++程序员来说是成立的。</font></p>
<p><font size="2">这本书填补了C++模板书籍领域由来已久的空白。此前，上有《Modern C++ Design》这样的专注于模板高级编程技术和泛型模式的著作，下有《The C++ Standard Library》这样的针对特定模板框架和组件的使用指南。然而，假如对模板机制缺乏深入的理解，你就很难“上下”自如。鉴于此，我向每一位渴望透彻理解 C++模板技术的朋友推荐这本书。</font></p>
<p><font size="2">这本书在大陆、台湾各有一个译本，但出自不同的译者之手。当你看到这篇文章时，两个译本应该都已经上市，对于读者来说当然也就多了一种选择。侯捷先生个人网站上开放了繁体译本大部分章节，不妨先睹为快。</font></p>
<p align="center"><a href="http://www.dearbook.com.cn/book/3554" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image0012.jpg" border="0"></font></a><a href="http://www.dearbook.com.cn/book/7725" target="_blank"><font size="2"><img hspace="30" src="http://book.csdn.net/BookFiles/69/04/image0012a.jpg" border="0"></font></a></p>
<h5 align="center">Andrei Alexandrescu,《C++设计新思维：泛型编程与设计模式之应用》<a href="http://www.dearbook.com.cn/book/3554" target="_blank"><font color="#000080">影印版</font></a>、<a href="http://www.dearbook.com.cn/book/7725" target="_blank"><font color="#000080">中文版</font></a></h5>
<p><font size="2">你自认为是C++模板编程高手吗？请看过这本书再回答。这是一本出自天才之手令人敬畏的杰作。泛型模式，无限延伸你的视野，足以挑战任何一名C++程序员的思维极限。</font></p>
<p><font size="2">这本书共分为两大部分，第一部分讨论了 Loki程序库采用的基础技术以及一些高级语言特性，包括基于策略的类设计、模板局部特化、编译期断言、Typelist以及小型对象分配技术等。第二部分则着重介绍了Loki中的重要组件和泛型模式技术，包括泛化仿函数（Generalization Functor）、单件（Singleton）、智能指针、对象工厂（Object Factory）、抽象工厂（Abstract Factory）、访问者（Visitor）以及多方法（Multimethods）等。每一种技术都让人大开眼界，叹为观止。</font></p>
<p><font size="2">在C++的学习方面，过犹不及往往成了不求甚解的借口。然而，面向对象并非C++的全部，模板和泛型编程亦占半壁江山。对于“严肃”的C++程序员而言，及时跟进这项早经例证的成功技术，不失为明智之举。</font></p>
<h3><font size="2">结语</font></h3>
<p><font size="2">这些著作是如此大名鼎鼎，也许根本不缺我一个推荐。然而，纵然C++程序员队伍的发展壮大速度不像其他更时髦的语言那样迅速，新人进总是多于旧人出。除了热忱地欢迎新人，我个人认为到了对C++书籍进行“盘点”的时候了，并且希望这样的“盘点”有益于感兴趣的读者。请保持耐心和宽厚。在下篇中，我将继续介绍标准库、网络编程以及其他方面的C++好书。有好书相伴，这个冬天不会冷。</font></p> <a href="http://hi.baidu.com/wuxyy/blog/item/a719271f311554caa686695d.html">阅读全文</a>
		
		<br/><b>类别：</b><a href="http://hi.baidu.com/wuxyy/blog/category/c%26%2347%3Bc%2B%2B">c&#47;c++</a>&nbsp;<a href="http://hi.baidu.com/wuxyy/blog/item/a719271f311554caa686695d.html#comment">查看评论</a>]]></description>
        <pubDate>2007-07-25  10:36</pubDate>
        <category><![CDATA[c&#47;c++]]></category>
        <author><![CDATA[wuxyy]]></author>
		<guid>http://hi.baidu.com/wuxyy/blog/item/a719271f311554caa686695d.html</guid>
</item>

<item>
        <title><![CDATA[SRM 360]]></title>
        <link><![CDATA[http://hi.baidu.com/wuxyy/blog/item/ac909d3d56f25402baa167ec.html]]></link>
        <description><![CDATA[
		
		<p><font size="2">这场SRM参赛人数达到了1322人。</font></p>
<p><font size="2">250pt，我做得算慢的，用了20min，只得到198.64pt.</font></p>
<p><font size="2">500pt，用了35min，得到264.26pt. 这题我的方法跟大部分人都不一样。按理说，很容易想到别人那种方法，可我的思维就是跟一般人不太一样。很多时候，我还是不愿意用数学证明，而喜欢凭着感觉找规律。还好我最后也通过了所有数据。</font></p>
<p><font size="2">1000pt,到比赛结束才刚敲完，还有错误，没提交成。</font></p>
<p><font size="2">系统测试，500pt 挂了一大片，我也从div2 100名升到30名，Room 4升到2.</font></p>
<p><font size="2">Rating总算升了一百，TCCC快到了，我状态貌似也回来了 :-)</font></p> <a href="http://hi.baidu.com/wuxyy/blog/item/ac909d3d56f25402baa167ec.html">阅读全文</a>
		
		<br/><b>类别：</b><a href="http://hi.baidu.com/wuxyy/blog/category/Topcoder">Topcoder</a>&nbsp;<a href="http://hi.baidu.com/wuxyy/blog/item/ac909d3d56f25402baa167ec.html#comment">查看评论</a>]]></description>
        <pubDate>2007-07-25  01:48</pubDate>
        <category><![CDATA[Topcoder]]></category>
        <author><![CDATA[wuxyy]]></author>
		<guid>http://hi.baidu.com/wuxyy/blog/item/ac909d3d56f25402baa167ec.html</guid>
</item>

<item>
        <title><![CDATA[SRM 359]]></title>
        <link><![CDATA[http://hi.baidu.com/wuxyy/blog/item/c3b034d15694c33a9a502770.html]]></link>
        <description><![CDATA[
		
		<p><font size="2">只做了500pt的题，得到300pt.</font></p>
<p><font size="2">250pt的题，题目步长，但我竟然没看懂题意，真是无语。。。</font></p>
<p><font size="2">浪费了拿$的好机会。</font></p> 
		
		<br/><b>类别：</b><a href="http://hi.baidu.com/wuxyy/blog/category/Topcoder">Topcoder</a>&nbsp;<a href="http://hi.baidu.com/wuxyy/blog/item/c3b034d15694c33a9a502770.html#comment">查看评论</a>]]></description>
        <pubDate>2007-07-22  01:52</pubDate>
        <category><![CDATA[Topcoder]]></category>
        <author><![CDATA[wuxyy]]></author>
		<guid>http://hi.baidu.com/wuxyy/blog/item/c3b034d15694c33a9a502770.html</guid>
</item>


</channel>
</rss>