hdu 2018 多校 第九场

jls的自闭场

1001 BPM136 差点首杀结果发现漏乘了一个系数还爆了ll,回来首杀就没了QAQQQ

 1 /* ***********************************************
 2 Author        :BPM136
 3 Created Time  :2018/8/20 12:19:25
 4 File Name     :1001.cpp
 5 ************************************************ */
 6 
 7 #include<iostream>
 8 #include<cstdio>
 9 #include<algorithm>
10 #include<cstdlib>
11 #include<cmath>
12 #include<cstring>
13 #include<iomanip>
14 #include<bitset>
15 #include<queue>
16 #include<ctime>
17 #include<set>
18 #include<map>
19 #include<list>
20 #include<vector>
21 #include<cassert>
22 #include<functional>
23 #define pb push_back
24 #define popb pop_back
25 #define MID ((l+r)>>1)
26 #define LSON (k<<1)
27 #define RSON (k<<1|1)
28 #define get(a,i) ((a)&(1<<(i-1)))
29 #define PAU putchar(32)
30 #define ENT putchar(10)
31 #define all(x) ((int) (x).size())
32 #define clr(a,b) memset(a,b,sizeof(a))
33 #define rep(_i,_a,_b) for(int _i=(_a);_i<=(_b);_i++)
34 #define down(_i,_a,_b) for(int _i=(_a);_i>=(_b);_i--)
35 #define FOR(_i,_b) for(int _i=1;_i<=(_b);_i++)
36 #define efo(_i,_a) for(int _i=last[(_a)];_i!=0;_i=e[_i].next)
37 #define Remax(a,b) if(b>a) a=b;
38 #define Remin(a,b) if(b<a) a=b;
39 #define SZ(x) ((int)(x).size())
40 #define filein(x) freopen(#x".in","r",stdin)
41 #define fileout(x) freopen(#x".out","w",stdout)
42 #define file(x) freopen(#x".in","r",stdin),freopen(#x".out","w",stdout);
43 #define mkd(x) freopen(#x".in","w",stdout);
44 #define setlargestack(x) int _SIZE=x<<20;char *_PPP=(char*)malloc(_SIZE)+_SIZE;__asm__("movl %0, %%esp\n" :: "r"(_PPP));
45 #define END system("pause")
46 #define read2(a,b) read(a),read(b)
47 #define read3(a,b,c) read(a),read(b),read(c)
48 #define readg(_x1,_y1,_x2,_y2) read(_x1),read(_y1),read(_x2),read(_y2)
49 using namespace std;
50 
51 typedef long long ll;
52 typedef double DB;
53 typedef long double LD;
54 typedef unsigned int  UI;
55 typedef unsigned long long ULL;
56 typedef vector<int> VI;
57 typedef set<int> SI;
58 typedef set<int , greater<int> > SIG;
59 typedef map<int, int > MII;
60 typedef map<int, int, greater<int> > MIIG;
61 
62 const int N = 81;
63 
64 ll f[N*N][N][N];
65 int n,m,MOD;
66 
67 int main() {
68     int T;
69     scanf("%d",&T);
70     while(T--) {
71         scanf("%d%d%d",&n,&m,&MOD);
72         clr(f,0);
73 
74         f[1][1][1]=n*m;
75         rep(i,1,n*m-1) rep(j,1,min(i,n)) rep(k,1,min(i,m)) if(i<=j*k) {
76             int leaf=j*k-i;
77             if(leaf) f[i+1][j][k]=(f[i+1][j][k]+f[i][j][k]*leaf%MOD)%MOD;
78 
79             //col
80             f[i+1][j][k+1]=(f[i+1][j][k+1]+f[i][j][k]*(m-k)*j%MOD)%MOD;
81             //row
82             f[i+1][j+1][k]=(f[i+1][j+1][k]+f[i][j][k]*(n-j)*k%MOD)%MOD;
83         }
84         cout<<f[n*m][n][m]<<endl;
85     }
86     return 0;
87 }
View Code

 

1002 BPM136 打了几个不同的版本然后不断用自己的暴力把自己疯狂hack,改了几次还是过了嘿嘿嘿( 然后愉快的自闭10

  1 /* ***********************************************
  2 Author        :BPM136
  3 Created Time  :2018/8/20 13:20:47
  4 File Name     :1002.cpp
  5 ************************************************ */
  6 
  7 #include<iostream>
  8 #include<cstdio>
  9 #include<algorithm>
 10 #include<cstdlib>
 11 #include<cmath>
 12 #include<cstring>
 13 #include<iomanip>
 14 #include<bitset>
 15 #include<queue>
 16 #include<ctime>
 17 #include<set>
 18 #include<map>
 19 #include<list>
 20 #include<vector>
 21 #include<cassert>
 22 #include<functional>
 23 #define pb push_back
 24 #define popb pop_back
 25 #define MID ((l+r)>>1)
 26 #define LSON (k<<1)
 27 #define RSON (k<<1|1)
 28 #define get(a,i) ((a)&(1<<(i-1)))
 29 #define PAU putchar(32)
 30 #define ENT putchar(10)
 31 #define all(x) ((int) (x).size())
 32 #define clr(a,b) memset(a,b,sizeof(a))
 33 #define rep(_i,_a,_b) for(int _i=(_a);_i<=(_b);_i++)
 34 #define down(_i,_a,_b) for(int _i=(_a);_i>=(_b);_i--)
 35 #define FOR(_i,_b) for(int _i=1;_i<=(_b);_i++)
 36 #define efo(_i,_a) for(int _i=last[(_a)];_i!=0;_i=e[_i].next)
 37 #define Remax(a,b) if(b>a) a=b;
 38 #define Remin(a,b) if(b<a) a=b;
 39 #define SZ(x) ((int)(x).size())
 40 #define filein(x) freopen(#x".in","r",stdin)
 41 #define fileout(x) freopen(#x".out","w",stdout)
 42 #define file(x) freopen(#x".in","r",stdin),freopen(#x".out","w",stdout);
 43 #define mkd(x) freopen(#x".in","w",stdout);
 44 #define setlargestack(x) int _SIZE=x<<20;char *_PPP=(char*)malloc(_SIZE)+_SIZE;__asm__("movl %0, %%esp\n" :: "r"(_PPP));
 45 #define END system("pause")
 46 #define read2(a,b) read(a),read(b)
 47 #define read3(a,b,c) read(a),read(b),read(c)
 48 #define readg(_x1,_y1,_x2,_y2) read(_x1),read(_y1),read(_x2),read(_y2)
 49 using namespace std;
 50 
 51 typedef long long ll;
 52 typedef double DB;
 53 typedef long double LD;
 54 typedef unsigned int  UI;
 55 typedef unsigned long long ULL;
 56 typedef vector<int> VI;
 57 typedef set<int> SI;
 58 typedef set<int , greater<int> > SIG;
 59 typedef map<int, int > MII;
 60 typedef map<int, int, greater<int> > MIIG;
 61 
 62 const int N = 2005;
 63 const int MOD = 998244353;
 64 
 65 int f[N][N];
 66 int n,m,K;
 67 
 68 int a[N][N];
 69 
 70 char s[N];
 71 ll sta_ans;
 72 int sta_l,sta_r;
 73 
 74 int add[N][N];
 75 int minu[N][N];
 76 
 77 int main() {
 78     int T;
 79     scanf("%d",&T);
 80     while(T--) {
 81         scanf("%d%d%d",&n,&m,&K);
 82         rep(i,1,n) {
 83             scanf("%s",s+1);
 84             rep(j,1,m) if(s[j]=='1') a[i][j]=1; else a[i][j]=0;
 85             a[i][0]=-1;
 86         }
 87 
 88 
 89         clr(f,0); clr(add,0); clr(minu,0);
 90         rep(i,1,m) f[1][i]=1;
 91         rep(i,2,n) {
 92             sta_l=1,sta_r=0;
 93             sta_ans=0;
 94             rep(j,1,m) {
 95                 while(sta_r<m && sta_r<j+K) {
 96                     sta_r++;
 97                     if(a[i-1][sta_r]!=a[i-1][sta_r-1]) {
 98                         sta_ans=sta_ans+f[i-1][sta_r];
 99                         add[i][j]+=f[i-1][sta_r];
100                         if(sta_ans>MOD) sta_ans-=MOD;
101                         if(add[i][j]>MOD) add[i][j]-=MOD;
102                     } else {
103                         sta_ans+=add[i-1][sta_r];
104                         add[i][j]+=add[i-1][sta_r];
105                         if(sta_ans>MOD) sta_ans-=MOD;
106                         if(add[i][j]>MOD) add[i][j]-=MOD;
107                     }
108                 }
109                 while(sta_l<sta_r && sta_l<j-K) {
110                     sta_l++;
111                     if(a[i-1][sta_l]!=a[i-1][sta_l-1]) {
112                         sta_ans-=f[i-1][sta_l-1];
113                         minu[i][j]+=f[i-1][sta_l-1];
114                         if(sta_ans<0) sta_ans+=MOD;
115                         if(minu[i][j]>MOD) minu[i][j]-=MOD;
116                     } else {
117                         sta_ans-=minu[i-1][sta_l];
118                         minu[i][j]+=minu[i-1][sta_l];
119                         if(sta_ans<0) sta_ans+=MOD;
120                         if(minu[i][j]>MOD) minu[i][j]-=MOD;
121                     }
122                 }
123                 f[i][j]=sta_ans;
124             }
125         }
126         ll ans=0;
127         rep(i,1,m) if(a[n][i]!=a[n][i-1]) {
128             ans+=f[n][i];
129             if(ans>MOD) ans-=MOD;
130         } else {
131             ans+=add[n][i];
132             if(ans>MOD) ans-=MOD;
133         }
134         cout<<ans<<endl;
135     }
136     return 0;
137 }
View Code

 

1004 小洛洛 小甜甜 智障题然而大家一开始都不会QAQ

 1 #include <iostream>
 2 #include <cstdio>
 3 #include <algorithm>
 4 #include <cmath>
 5 #include <vector>
 6 #include <queue>
 7 #include <set>
 8 #include <map>
 9 #include <string>
10 #include <string.h>
11 #include <stdlib.h>
12 #include <time.h>
13 #include <climits>
14 
15 using namespace std;
16 
17 void work(){
18     long long a,b,c,aa,bb,cc;
19     scanf("%lld%lld%lld",&a,&b,&c);
20     scanf("%lld%lld%lld",&aa,&bb,&cc);
21 
22     long long down=(a+b+c);
23     long long up=0;
24 
25     up+=aa*(c-b);
26     up+=bb*(a-c);
27     up+=cc*(b-a);
28 
29     long long g=__gcd(up,down);
30     g=abs(g);
31     up/=g;
32     down/=g;
33 
34     if (down==1) printf("%lld\n",up);
35     else printf("%lld/%lld\n",up,down);
36 }
37 
38 int main(){
39     int T;
40     scanf("%d",&T);
41     while (T--) work();
42     return 0;
43 }
View Code

 

1010 有没有人告诉我为什么能直接取两个log啊? 我们数分老师告诉我们不可以啊? 取一个的话可以证明可以,但是两个的话绕不过一个e^(clnb)次方啊? 是不是什么地方姿势不是很对啊。。。。

1011 小甜甜

 1 #include <iostream>
 2 #include <cstdio>
 3 #include <algorithm>
 4 #include <cmath>
 5 #include <vector>
 6 #include <queue>
 7 #include <set>
 8 #include <map>
 9 #include <string>
10 #include <string.h>
11 #include <stdlib.h>
12 #include <time.h>
13 #include <climits>
14 
15 using namespace std;
16 
17 const int maxN=1e7+7;
18 const int mod=998244353;
19 
20 long long fact[maxN],invf[maxN];
21 long long base[maxN];
22 
23 long long poww(long long x,long long k){
24     long long ret=1;
25     while (k){
26         if (k&1) ret=ret*x%mod;
27         k>>=1;
28         x=x*x%mod;
29     }
30     return ret;
31 }
32 
33 void work(){
34     int a,b,c,d;
35     scanf("%d%d%d%d",&a,&b,&c,&d);
36 
37     long long ans=0;
38 
39     long long B=1;
40     if (b>=1) B+=b;
41     ans+=B*base[c];
42     ans%=mod;
43 
44     ans+=base[b]-B;
45     ans%=mod;
46     
47     if (d>=1) {
48         ans+=base[c]*d;
49         ans%=mod;
50     }
51 
52     ans=ans*base[a]%mod;
53 
54     printf("%lld\n",ans);
55 }
56 
57 int main(){
58     fact[0]=invf[0]=1;
59     base[0]=1;
60     for (int i=1;i<maxN;i++) fact[i]=fact[i-1]*i%mod,base[i]=base[i-1]*2%mod;
61     invf[maxN-1]=poww(fact[maxN-1],mod-2);
62     for (int i=maxN-2;i>0;i--) invf[i]=invf[i+1]*(i+1)%mod;
63 
64     int T;
65     scanf("%d",&T);
66     while (T--) work();
67     return 0;
68 }
View Code

 

posted @ 2018-08-20 20:33  My_Girlfriends  阅读(301)  评论(0编辑  收藏  举报