A - Promotions
生活随笔
收集整理的這篇文章主要介紹了
A - Promotions
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
題目詳見http://7xjob4.com1.z0.glb.clouddn.com/3f644de6844d64706eb36baa3a0c27b0
這題是普通的拓撲排序,要把每一層的都保存下來。
#include<iostream> #include<stdio.h> #include<stdlib.h> #include<string.h> #include<math.h> #include<vector> #include<map> #include<set> #include<queue> #include<stack> #include<string> #include<algorithm> using namespace std; typedef long long ll; #define inf 99999999 #define pi acos(-1.0) #define MOD 1000000007 struct edge{int to,next; }e[2*20050]; int first[5050],du[5050]; int q[1111111]; int n,m; int ceng[5050][5050],num[5050],deep[5050],cengshu,sum[5050];void topu() {int i,j;int front,rear;front=1;rear=0;memset(num,0,sizeof(num));memset(deep,0,sizeof(deep));for(i=1;i<=n;i++){if(!du[i]){rear++;q[rear]=i;deep[i]=1;}}int x,y,xx,yy;cengshu=1;while(front<=rear){x=q[front];front++;cengshu=max(cengshu,deep[x]);num[cengshu]++;ceng[cengshu ][num[cengshu] ]=x;for(i=first[x];i!=-1;i=e[i].next){int v=e[i].to;du[v]--;if(!du[v]){rear++;q[rear]=v;deep[v]=deep[x]+1;}}}sum[0]=0;for(i=1;i<=cengshu;i++){sum[i]=sum[i-1]+num[i];} }int main() {int i,j,l,r,tot,c,d;while(scanf("%d%d%d%d",&l,&r,&n,&m)!=EOF){memset(first,-1,sizeof(first));memset(du,0,sizeof(du));tot=0;for(i=1;i<=m;i++){scanf("%d%d",&c,&d);c++;d++;du[d]++;tot++;e[tot].next=first[c];e[tot].to=d;first[c]=tot;}topu();int num1,num2,num3;for(i=1;i<=cengshu;i++){if(sum[i]>l)break;}i--;num1=sum[i];for(i=1;i<=cengshu;i++){if(sum[i]>r)break;}i--;num2=sum[i];for(i=1;i<=cengshu;i++){if(sum[i]>=r)break;}if(i>=cengshu)num3=0;else num3=sum[cengshu]-sum[i];printf("%d\n%d\n%d\n",num1,num2,num3);}return 0; }轉載于:https://www.cnblogs.com/herumw/p/9464599.html
總結
以上是生活随笔為你收集整理的A - Promotions的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Error -26612: HTTP S
- 下一篇: 神经网络那些事儿(二)