栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

zoj 1167 Trees on the Level

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

zoj 1167 Trees on the Level

#include <map>#include <string>#include <iostream>#include <stdlib.h>using namespace std;class MySort{    public:    bool operator ()(const string  A,const string  B) const    {        if(A.length() < B.length() ) return true;        else if( A.length() == B.length() && A < B ) return true;        return false;    }};map<string,int,MySort> Tree;bool Insert(string str){   string temp = str.substr(1,str.length()-2);    int pos = temp.find(',');    string key = temp.substr(pos+1);    string t = temp.substr(0,pos);    int value = atoi( t.c_str() );    if( Tree.find(key)!=Tree.end() )        return false;    else    {        Tree.insert( map<string,int,MySort>::value_type(key,value) );        return true;    }}bool HaveRoot(){    for(map<string,int,MySort>::iterator i=Tree.begin();i!=Tree.end();i++)    {        string str = i->first;if( str.length() == 0 ) continue;        if( Tree.find(str.substr(0,str.length()-1)) == Tree.end() ) return false;    }    return true;}int main(){    string str;    bool flag = true;    while( cin>>str )    {        if(str == "()")        { if( flag && HaveRoot() ) {     map<string,int,MySort>::iterator i;     for( i=Tree.begin();i!=Tree.end();i++ )     {         if( i!=Tree.begin() )  cout << ' ';         cout << (*i).second ;     }     cout << endl; } else {     cout << "not complete"<<endl; } Tree.clear(); flag = true;        }        else        { if( !Insert(str) )     flag = false;        }    }    return 0;}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/369300.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号