23333再次水惨了。。(心酸啊)

A题呵呵呵呵呵

 #include<cstdio>
#include<iostream>
using namespace std;
int main()
{
int ans=;
int n; cin>>n;
for (int i=; i<=n; i++)
{
string ch; cin>>ch;
if (ch[]=='T') ans+=;
if (ch[]=='C') ans+=;
if (ch[]=='O') ans+=;
if (ch[]=='D') ans+=;
if (ch[]=='I') ans+=;
}
cout<<ans;
return ;
}

B题,,,最后是不对的。。。(被fst了?我也不知道叫什么)

2333就是因为初始化变量的时候吧0x7fffffff达成了0x7ffffff(没错,少了一个f,,导致这个数比1e9小,然后就完蛋了)

 #include<iostream>
#include<bits/stdc++.h>
using namespace std;
int main()
{
int n; cin>>n;
int ansy1=0x7fffffff,ansx1=;
for (int i=; i<=n; i++)
{
int x,y; cin>>x>>y;
ansy1=min(y,ansy1);
ansx1=max(x,ansx1);
}
int ansx2=,ansy2=0x7fffffff; int m; cin>>m;
for (int i=; i<=m; i++)
{
int x,y; cin>>x>>y;
ansx2=max(x,ansx2);
ansy2=min(ansy2,y);
}
cout<<max(,max(ansx2-ansy1,ansx1-ansy2));
}

C题比赛的时候还被hack了2333,,又是因为一个sb问题,(二分的右边界开小了,1e9是不够的。。呵呵呵,真的是到了晚上IQ=-inf了)

C题做的时候水的也比较惨,感觉暴力不对,就开始写二分。

n<m:然后一开始的前m天肯定是(直到m+1天的没吃之前,都是n),ans一开始直接搞成m,那么后面就是考虑这一天能不能被吃完,吃完的情况就是n-(x-1)*x/2<m+x的(这里的x是出去前m天,然后从1开始的),这是可以二分的。所以就各种调。。调到1个多小时。

 #include<bits/stdc++.h>
#define LL long long
using namespace std;
LL n,m;
LL find(LL x)
{
LL l=,r=3e9;
while (l<r)
{
LL mid=l+r>>;
if (n-(mid-)*mid/==m+mid) return mid;
else if (n-mid*(mid-)/<m+mid) r=mid-;
else if (n-mid*(mid-)/>m+mid) l=mid+;
}
if (n-l*(l-)/>m+l) l++;
return l;
}
int main()
{
cin>>n>>m;
if (m>=n)
{
cout<<n;
return ;
}
LL tot=n;
int cnt=;
/*for (;;) //暴力手动对拍2333
{
tot+=m; if (tot>n) tot=n;
tot-=cnt++;
if (tot<=0)
{
cout<<cnt-1<<" ";
break;
}
}*/
LL ans=;
LL x=find(n);
ans=m;
cout<<ans+x;
return ;
}

D题还是比较神的。一开始,心里想,yao这不是(组合数学?!!),(一般就不会了)

然而再一看还是挺简单的。。只需要对一个位置 i 搞出前面有多少个"(" (n个) 和后面有多少个")" (m个) 就好了,枚举每一个 “(” 的位置,每个位置的贡献就是 sigma(C(n-1,i-1)*C(m,i))(i: 1->min(n,m))

(取C(n-1,i-1)的原因就是要保证这一个"("一定要取到)

然而看了一下范围瞬间就蛋疼了。。(抱着侥幸的心理,感觉CF的评测机飞快,一秒跑个10的十几次方没什么问题吧(大雾),就写了那个暴力交上了。。第6个点就T了)

扒题解:有个神奇的东西交范德蒙恒等式!!!%%%  http://blog.csdn.net/acdreamers/article/details/31032763

现在的每个位置的贡献貌似不能直接用范德蒙的那个公式算,,变一下形,变成 sigma(C(n,i)*C(m,i))-sigma(C(n',i)*C(m,i)) (i:1->min(n,m) (min(n',m)))(n'为上一个"("位置,"("的数量)

这样就可以用sigma(C(n,i)*C(m,i))==C(n+m,min(n,m))了,然而这个公式是从0开始的然后我们用的时候要减1,然后后面也减1就抵消了,,23333

这下直接秒A

里面还有一个处理逆元,阶乘什么的鬼东西(反正都是原来从题解上扒下来的)

(吐槽,我感觉这个sb公式要是白天脑子清醒的话能自己手玩(推)出来吧。。。。)

 #include<bits/stdc++.h>
#define N 200005<<1
#define M 200000<<1
#define LL long long
using namespace std;
const int mod=1e9+;
char ch[N];
LL ans,fac[N],inv[N];
int n,sum1[N],sum2[N];
LL ksm(LL x, int p)
{
LL sum=;
for (;p;p>>=,x=x*x%mod)
if (p&) sum=sum*x%mod;
return sum%mod;
}
LL C(int n, int m)
{
return fac[n]*inv[m]%mod*inv[n-m]%mod;
}
int main()
{
scanf("%s",ch+);
n=strlen(ch+);
for (int i=; i<=n; i++)
if (ch[i]=='(') sum1[i]=sum1[i-]+; else sum1[i]=sum1[i-];
for (int i=n; i>=; i--)
if (ch[i]==')') sum2[i]=sum2[i+]+; else sum2[i]=sum2[i+];
inv[]=fac[]=;
for (int i=; i<=M; i++) fac[i]=fac[i-]*i%mod;
inv[M]=ksm(fac[M],mod-);
for (int i=M; i>=; i--) inv[i-]=inv[i]*i%mod;
int last=;
for (int i=; i<=n; i++)
if (ch[i]=='(')
{
// cout<<C(last+sum2[i],min(last,sum2[i]));
ans=((ans+C(sum1[i]+sum2[i],min(sum1[i],sum2[i]))-C(last+sum2[i],min(last,sum2[i]))+mod)%mod)%mod;//while (1);
last=sum1[i];
}
cout<<ans%mod;
return ;
}

cf 785#的更多相关文章

  1. ORA-00494: enqueue [CF] held for too long (more than 900 seconds) by 'inst 1, osid 5166'

    凌晨收到同事电话,反馈应用程序访问Oracle数据库时报错,当时现场现象确认: 1. 应用程序访问不了数据库,使用SQL Developer测试发现访问不了数据库.报ORA-12570 TNS:pac ...

  2. cf之路,1,Codeforces Round #345 (Div. 2)

     cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅.....   ...

  3. cf Round 613

    A.Peter and Snow Blower(计算几何) 给定一个点和一个多边形,求出这个多边形绕这个点旋转一圈后形成的面积.保证这个点不在多边形内. 画个图能明白 这个图形是一个圆环,那么就是这个 ...

  4. ARC下OC对象和CF对象之间的桥接(bridge)

    在开发iOS应用程序时我们有时会用到Core Foundation对象简称CF,例如Core Graphics.Core Text,并且我们可能需要将CF对象和OC对象进行互相转化,我们知道,ARC环 ...

  5. [Recommendation System] 推荐系统之协同过滤(CF)算法详解和实现

    1 集体智慧和协同过滤 1.1 什么是集体智慧(社会计算)? 集体智慧 (Collective Intelligence) 并不是 Web2.0 时代特有的,只是在 Web2.0 时代,大家在 Web ...

  6. CF memsql Start[c]UP 2.0 A

    CF memsql Start[c]UP 2.0 A A. Golden System time limit per test 1 second memory limit per test 256 m ...

  7. CF memsql Start[c]UP 2.0 B

    CF memsql Start[c]UP 2.0 B B. Distributed Join time limit per test 1 second memory limit per test 25 ...

  8. CF #376 (Div. 2) C. dfs

    1.CF #376 (Div. 2)    C. Socks       dfs 2.题意:给袜子上色,使n天左右脚袜子都同样颜色. 3.总结:一开始用链表存图,一直TLE test 6 (1)如果需 ...

  9. CF #375 (Div. 2) D. bfs

    1.CF #375 (Div. 2)  D. Lakes in Berland 2.总结:麻烦的bfs,但其实很水.. 3.题意:n*m的陆地与水泽,水泽在边界表示连通海洋.最后要剩k个湖,总要填掉多 ...

随机推荐

  1. YUV 和 YCbCr 辨析

    YCbCr或Y'CbCr 是在世界数字组织视频标准研制过程中作为ITU-R BT1601 建议的一部分, 其实是YUV经过缩放和偏移的翻版. 通常会用于影片中的影像连续处理,或是数字摄影系统中. 其中 ...

  2. 【JAVA蓝桥杯】基础练习2 十六进制转十进制

    资源限制 时间限制:1.0s   内存限制:512.0MB 问题描述 从键盘输入一个不超过8位的正的十六进制数字符串,将它转换为正的十进制数后输出. 注:十六进制数中的10~15分别用大写的英文字母A ...

  3. Dubbo与SpringBoot整合流程(从实例入手,附代码下载)

    场景 Dubbo环境搭建-管理控制台dubbo-admin实现服务监控: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/10362 ...

  4. 【剑指Offer面试编程题】题目1389:变态跳台阶--九度OJ

    题目描述: 一只青蛙一次可以跳上1级台阶,也可以跳上2级--它也可以跳上n级.求该青蛙跳上一个n级的台阶总共有多少种跳法. 输入: 输入可能包含多个测试样例,对于每个测试案例, 输入包括一个整数n(1 ...

  5. Date.parse在IE/Firefox下有兼容性问题

    原因: IE和Firefox是不支持含有'-'字符的日期格式,如:"2018-11-23" 解决方法: 日期格式 'yyyy-mm-dd' 改成 'yyyy/mm/dd' 代码: ...

  6. SpringMVC--文件上传与下载

    http://blog.csdn.net/u012706811/article/details/51059419

  7. js select下拉框下拉跳转代码

    下拉跳转原理很简单这个用到了select的onchangeg事件,只要这里改变我们就获取select值直接location.href=this.value即可. <select name=&qu ...

  8. Codeforces Round #199 (Div. 2) D. Xenia and Dominoes

    把 'O' 看成 'X',然后枚举它的四个方向看看是否能放,然后枚举 $2^4$ 种可能表示每种方向是否放了,放了的话就标成 'X',就相当于容斥,对于新的图去dp. dp就是铺地砖,行用二进制来表示 ...

  9. WordPress获取首页网站链接和站点名称

    利用bloginfo 获取WordPress网站名称和主页链接 用法一: $blog_title = get_bloginfo('name'); //获取站点名称 $linkzmki = get_bl ...

  10. mysql分区介绍

    http://www.cnblogs.com/chenmh/p/5644713.html 介绍 可以针对分区表的每个分区指定各自的存储路径,对于innodb存储引擎的表只能指定数据路径,因为数据和索引 ...