首页 > 代码库 > 2017/8/4 考试吐槽
2017/8/4 考试吐槽
2017 8 4 得分:110
一句话:江南皮革厂倒闭了!会的东西全带着他们的小姨子跑了!成绩统统二十分!统统二十分!
A、聪明的质检员
链接:http://cogs.pro/cogs/problem/problem.php?pid=631
题意:找到一个式子:Y_i = \sum_j 1 \times \sum_j v_j , j \in [L_i, R_i] \text{且} w_j \ge W, j \text{是矿石编号}与标准差绝对值最小的情况。
吐槽:二分写成三分……少写一个库……心里苦啊……考试时就这么……100分飞了……(╯‵□′)╯︵┻━┻/(ㄒoㄒ)/~~/(ㄒoㄒ)/~~
题解:不要被那个该死的绝对值吓到而投奔三分!去掉绝对值,我们就会发现,这个狗比函数是单调下降的!于是我们改用二分!二分时要注意,函数值大于标准差测一个,小于标准差再测一个!还有就是,验证答案的时候不要XJB用什么数据结构!(数据结构学傻了---$ysf$)一个前缀和足够!恭喜成为优化加$log$成员!给这位仁兄让个地方……唉不说了说多了都是泪啊啊……
还有就是:多用$long long$!
1 #include<iostream> 2 #include<algorithm> 3 #include<cstdlib> 4 #include<cstdio> 5 #include<cstring> 6 using namespace std; 7 const int maxn=200005; 8 int n,m,l[maxn],r[maxn],w[maxn],v[maxn]; 9 long long sumt[maxn],sumn[maxn],s; 10 long long check(int vall) 11 { 12 for(int i=1;i<=n;i++) 13 { 14 sumt[i]=sumt[i-1],sumn[i]=sumn[i-1]; 15 if(w[i]>=vall)sumt[i]++,sumn[i]+=v[i]; 16 } 17 long long ans=0; 18 for(int i=1;i<=m;i++) 19 { 20 ans+=(sumn[r[i]]-sumn[l[i]-1])*(sumt[r[i]]-sumt[l[i]-1]); 21 } 22 return ans-s; 23 } 24 int haha() 25 { 26 freopen("qc.in","r",stdin); 27 freopen("qc.out","w",stdout); 28 scanf("%d%d%lld",&n,&m,&s); 29 int maxx=0,minn=1000001; 30 for(int i=1;i<=n;i++) 31 { 32 scanf("%d%d",&w[i],&v[i]); 33 maxx=max(maxx,w[i]); 34 minn=min(minn,w[i]); 35 } 36 for(int i=1;i<=m;i++)scanf("%d%d",&l[i],&r[i]); 37 int L=minn,R=maxx,mid; 38 long long ans=(long long)1e12; 39 while(L<=R) 40 { 41 mid=(L+R)>>1;long long t=check(mid); 42 if(t>=0)L=mid+1; 43 else R=mid-1; 44 ans=min(ans,abs(t)); 45 } 46 printf("%lld\n",ans); 47 } 48 int sb=haha(); 49 int main(){;}
B、lucky
听说是tyvj上有但是我怎么没找到呢……不管了直接描述题意:只含有4、7的数是幸运数,不含有出现两次及以上元素序列就是不幸运的。现在给出一个序列,问长度为k的不幸运序列有几种情况。
吐槽:表打小了……(╯‵□′)╯︵┻━┻吔屎……
题解:首先我们找出来最大值范围内所有的幸运数(打表或暴搜),然后,我们处理数列中每一个数字,计算出不是幸运数的个数和幸运数的种数。
对于每一个不是幸运数的数,我们可以看出这是个简单的组合问题,而对于是幸运数的,我们直接作为0-1背包处理,因为每个幸运数最多出现一次。因此,总的公式就是:
ans=\sum_{i=1}^k {\binom{d}{k-i} \times f_i}
1 #include<iostream> 2 #include<cstdio> 3 #include<cstring> 4 #include<algorithm> 5 using namespace std; 6 const long long mod=(long long)1e9+7; 7 long long c[100005],con[100025],f[100025];long long n,k; 8 long long qpow(long long q,long long tim) 9 { 10 long long tmp=q,l=1; 11 for(;tim;tim>>=1,tmp=tmp*tmp%mod) 12 if(tim&1)l=l*tmp%mod; 13 return l; 14 } 15 long long lucky_num[2050],cnt; 16 void dfs(long long val) 17 { 18 lucky_num[++cnt]=val; 19 if(1ll*val*10+4<=1e10)dfs(val*10+4); 20 if(1ll*val*10+7<=1e10)dfs(val*10+7); 21 } 22 long long ans; 23 long long tot; 24 int haha() 25 { 26 //freopen("lucky8.in","r",stdin); 27 //freopen("lucky.out","w",stdout); 28 dfs(4);dfs(7); 29 sort(lucky_num+1,lucky_num+cnt+1); 30 scanf("%lld%lld",&n,&k); 31 long long n2=n; 32 for(long long i=1;i<=n2;i++) 33 { 34 long long x;scanf("%lld",&x); 35 long long K=lower_bound(lucky_num+1,lucky_num+2046,x)-lucky_num; 36 if(lucky_num[K]==x) 37 { 38 con[K]++; 39 if(con[K]==2){n-=2;tot++;} 40 else if(con[K]>2)n--; 41 } 42 } 43 sort(con+1,con+2046,greater<long long>()); 44 c[0]=1; 45 for(long long i=1;i<=n;i++) 46 { 47 c[i]=(n-i+1)*c[i-1]%mod*qpow(i,mod-2)%mod; 48 } 49 f[0]=1; 50 for(long long i=1;i<=tot;i++) 51 for(long long j=i+1;j;j--) 52 f[j]=(f[j]%mod+f[j-1]*con[i]%mod)%mod; 53 long long tim=min(tot,k); 54 for(long long i=0;i<=tim;i++) 55 ans=(ans+c[k-i]*f[i]%mod)%mod; 56 printf("%lld\n",ans); 57 //while(1); 58 } 59 int sb=haha(); 60 signed main(){;}
C、兔农
链接:http://cogs.pro/cogs/problem/problem.php?pid=1374
题意:一个数列,与$Fibonacci$数列唯一的不同就在于如果$f[i]mod n=1$,$f[i]--$。求出这个数列对于一个模数取膜后的某一项。
吐槽:暴力答不对啊……死了得了……
题解:暴力好打,然而正解至今没有看懂(明明是你太蒻了好不好),只能丢链接加%dalao了……
$vfk$的:http://vfleaking.blog.163.com/blog/static/174807634201341721051604/
鏼的:http://jcvb.is-programmer.com/posts/39528.html
回来再填坑吧……(逃
2017/8/4 考试吐槽