设为首页 收藏本站
查看: 1569|回复: 0

[经验分享] HDU 4724 If You Know This,You Must Have NO GF 解题报告

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-11-24 01:52:24 | 显示全部楼层 |阅读模式
  题目
  题意:
  Make一个文件有三种命令:
  1、形如Target: [component ...],表示要生成Target,必须要先有所有的components,如果某个component还不存在,就先生成它。如果还是不行,就不生成Target。依赖关系不会成环。
  2、形如g++ a.o b.o -o main,完全可以忽略。
  3、如果行中有‘#’,则‘#’后的是注释,不用管。
  


  如果一行最后有‘\',表示和下一行是连在一起的,原本是同一行。
  


  这里的“This command will not get executed“有歧义,如果不能执行,究竟还是否生成那些能生成的components?我是能生成则生成,据说热身赛当天的标程是生成到第一个不能生成的component就停止。
  


  题解:
  就一个模拟,将文件名分离出来,用数字代替,然后就会得到一棵依赖树,dfs一遍即可。
  


  

//Time:31ms
//Memory:372KB
//Length:2361B
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <string>
#include <algorithm>
#include <map>
using namespace std;
#define MAXN 10005
map<string,int> ma;
int he[MAXN],to[MAXN],nex[MAXN],ntop,ans;
char s1[MAXN],s2[MAXN],*s3;
bool vi[600],ty[200];
void add(int u,int v)
{
to[ntop]=v;
nex[ntop]=he;
he=ntop&#43;&#43;;
}
bool cal(int h)
{
bool flag=true,f2=false;
if(vi[h])   return true;
for(int i=he[h];i!=-1;i=nex)
flag&=cal(to),f2=true;
vi[h]=flag&&f2;
ans&#43;=flag&&f2;
return vi[h];
}
char *mget(char *s)
{
if(s==NULL) return NULL;
for(int i=0,j=0;s&&s!='#';&#43;&#43;i)
if(ty[s])
{
for(;ty[s[i&#43;j]];&#43;&#43;j)    s2[j]=s[i&#43;j];
s2[j]='\0';
return s&#43;i&#43;j;
}
return NULL;
}
int main()
{
//freopen(&quot;/home/moor/Code/input&quot;,&quot;r&quot;,stdin);
int ncase,len,q,top,now;
scanf(&quot;%d&quot;,&ncase);
memset(ty,0,sizeof(ty));
for(int i=0;i<26;&#43;&#43;i)   ty[i&#43;'a']=ty[i&#43;'A']=1;
for(int i=0;i<10;&#43;&#43;i)    ty[i&#43;'0']=1;
ty['.']=1;
for (int hh=1;hh<=ncase;&#43;&#43;hh)
{
ntop=0;
top=1;
memset(he,-1,sizeof(he));
memset(vi,0,sizeof(vi));
ma.clear();
printf(&quot;%sCase #%d:\n&quot;,hh>1?&quot;\n&quot;:&quot;&quot;,hh);
s1[0]='\0';
while(gets(s1)&&(s1[0]=='\0'||s1[0]=='\n'||s1[0]=='\r'));
while(s1[0]!='=')
{
len=strlen(s1);
while(s1[len-1]=='\\')
{
gets(s2);
strcpy(&s1[len-1],s2);
len&#43;=strlen(s2)-1;
}
if(strstr(s1,&quot;:&quot;)==NULL)
{
gets(s1);
continue;
}
s3=s1;
s3=mget(s3);
if(ma.find(s2)==ma.end())       ma[s2]=top&#43;&#43;;
now=ma[s2];
while((s3=mget(s3))!=NULL)
{
if(ma.find(s2)==ma.end())       ma[s2]=top&#43;&#43;;
add(now,ma[s2]);
}
gets(s1);
}
scanf(&quot;%d&quot;,&q);
while(q--)
{
scanf(&quot;%s&quot;,s1);
if(ma.find(s1)!=ma.end())       vi[ma[s1]]=1;
}
scanf(&quot;%d&quot;,&q);
while(q--)
{
ans=0;
scanf(&quot;%s%s&quot;,s1,s2);
printf(&quot;%d\n&quot;,ma.find(s2)!=ma.end()?(cal(ma[s2])?ans:0):0);
}
gets(s1);
}
return 0;
}




  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-142784-1-1.html 上篇帖子: warning: implicit declaration of function ‘inet_ntop’解决办法 下篇帖子: inet_pton函数 和inet_ntop函数
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表