codeforces #232 div2 解题报告
A:简单题;我们可以把点换成段处理,然后枚举段看是否被霸占了;
#include<iostream>
#include<string>
#include<math.h>
#include<algorithm>
using namespace std;
int b[];
int main()
{
int n;
cin>>n;
int l,r;
cin>>l>>r;
for (int i=l;i<r;i++)
b[i+]=;
for (int i=;i<=n;i++)
{
cin>>l>>r;
for (int i=l;i<r;i++)
if (b[i+]) b[i+]=;
} int sum=;
for (int i=;i<=;i++)
if (b[i]) sum++;
cout<<sum<<endl;
return ;
}
B:数学题,题目越长越简单,这个道理没错啊,开始没推出来,猜了个结论;
可以达到的值的范围是[L,R],[2*L,2*R],[3*L,3*R],......[X*L,X*R],只可能是这些结果。。
所以XL<=ni<=X*R;
结论就是:
if (a/l*l<=a&&a/l*r>=a) cout<<"Yes"<<endl;
C题:题目简单,但是很难,没做出来。。。。
大概思路是:先将每个书分解质因数CI,然后将这CI个质因数分配到N个盒子里,组合数学求这个方案数:AI=C(ci+n-1,n-1);ps:我还推不出这个等式啊。。。。。
ANS=a[i]乘积%10000000007;
对了求C(N,M)=C(N-1,M-1)+C(N,M-1)可以运用数组求出
#include<iostream>
#include<algorithm>
#include<string.h>
#include<map>
using namespace std;
map<int,int> v;
const int mod=;
int c[][];
int n,a[],cnt=;
long long num[]; void getnum(int x)
{
for (int i=;i*i<=x;i++)
{
while (x%i==) {
if (v.count(i))
{
num[v[i]]++;
x/=i;
}
else{
v[i]=++cnt;
num[v[i]]++;
x/=i;
}
}
}
if (x==) return;
if (v.count(x))
num[v[x]]++;
else
{
v[x]=++cnt;
num[v[x]]++;
}
} int main()
{
c[][]=;
for (int i=;i<=;i++)
for (int j=;j<=i&&j<=;j++)
{
if (j==||j==i) c[i][j]=;
else
c[i][j]=(c[i-][j-]+c[i-][j])%mod;
} int n;
cin>>n;
for (int i=;i<=n;i++)
{
int x;
cin>>x;
getnum(x);
} long long ans=;
for (int i=;i<=cnt;i++)
ans=ans*c[num[i]+n-][n-]%mod;
cout<<ans<<endl;
return ;
}
D题:个人认为这题比C简单,赛后wo耐心的把公式推出了,其实也比较好推的
ANS:(v[i]-2)u[i]+2*(n-v[i]+1) / (2*u[i]*v[i]);
卡在求U[I],V[I];
居然有这样的神结论:因为10^9的素数很密集,可以直接暴力求解,吓尿了。。。。
#include<iostream>
#include<string.h>
#include<algorithm>
#include<math.h> using namespace std;
int prime[];
int cnt=;
int vis[+]; void init()
{
for (int i=;i<=;i++){
if (vis[i]) continue;
prime[++cnt]=i;
for (int j=i+i;j<=;j+=i)
vis[j]=;
}
} long long gcd(long long x,long long y)
{
if (x<y) swap(x,y);
if (x%y==) return y;
return gcd(y,x%y);
} long long find1(long long x)
{
while ()
{
int i=;
while (i<=cnt)
{
if (x%prime[i]==&&x!=prime[i]) {x--;i=;continue;}
i++;
}
return x;
}
} long long find2(long long x)
{
x++;
while ()
{
int i=;
while (i<=cnt)
{
if (x%prime[i]==&&x!=prime[i]) {x++;i=;continue;}
i++;
}
return x;
}
} int main()
{
int n;
init();
cin>>n;
for (int i=;i<=n;i++)
{
int x;
cin>>x;
long long l=find1(x),r=find2(x);
long long a=(l-)*r+*(x-l+),b=*(l*r);
cout<<a/gcd(a,b)<<"/"<<b/gcd(a,b)<<endl;
} return ;
}
可见我弱的一般性。。。
codeforces #232 div2 解题报告的更多相关文章
- Codeforces #263 div2 解题报告
比赛链接:http://codeforces.com/contest/462 这次比赛的时候,刚刚注冊的时候非常想好好的做一下,可是网上喝了个小酒之后.也就迷迷糊糊地看了题目,做了几题.一觉醒来发现r ...
- Codeforces Round#320 Div2 解题报告
Codeforces Round#320 Div2 先做个标题党,骗骗访问量,结束后再来写咯. codeforces 579A Raising Bacteria codeforces 579B Fin ...
- Codeforces Round #299 Div2 解题报告
这场比赛并没有打现场,昨天晚上做了ABCD四道题,今天做掉了E题 以前还没有过切完一场比赛的所有题呢~爽~ A. Tavas and Nafas Today Tavas got his test ...
- codeforces 31C Schedule 解题报告
题目链接:http://codeforces.com/problemset/problem/31/C 题目意思:给出 n 个 lessons 你,每个lesson 有对应的 起始和结束时间.问通过删除 ...
- codeforces 499B.Lecture 解题报告
题目链接:http://codeforces.com/problemset/problem/499/B 题目意思:给出两种语言下 m 个单词表(word1, word2)的一一对应,以及 profes ...
- codeforces 495C. Treasure 解题报告
题目链接:http://codeforces.com/problemset/problem/495/C 题目意思:给出一串只有三种字符( ')','(' 和 '#')组成的字符串,每个位置的这个字符 ...
- codeforces 490B.Queue 解题报告
题目链接:http://codeforces.com/problemset/problem/490/B 题目意思:给出每个人 i 站在他前面的人的编号 ai 和后面的人的编号 bi.注意,排在第一个位 ...
- CodeForces 166E -Tetrahedron解题报告
这是本人写的第一次博客,学了半年的基础C语言,初学算法,若有错误还请指正. 题目链接:http://codeforces.com/contest/166/problem/E E. Tetrahedro ...
- codeforces 489A.SwapSort 解题报告
题目链接:http://codeforces.com/problemset/problem/489/A 题目意思:给出一个 n 个无序的序列,问能通过两两交换,需要多少次使得整个序列最终呈现非递减形式 ...
随机推荐
- How to executing direct SQL statements [Axapta, AX4.0, AX2009, AX2012]
Today I want to talk about executing SQL statements in X++ on both the current AX database and exter ...
- Oracle中建表空间以及用户
第一步:创建临时表空间 --创建临时表空间-- CREATE TEMPORARY TABLESPACE JSYCCS_TEMP ---'JSYCCS_TEMP'临时表空间名 TEMPFILE 'E ...
- 基于devkit8600的2011.04版uboot启动代码Start.s分析
/* * armboot - Startup Code for OMAP3530/ARM Cortex CPU-core * * Copyright (c) 2004 Texas Instrument ...
- static关键字的作用
static可以用来定义静态成员变量.静态函数.静态代码块. 静态成员变量的语法特点 定义方法:在成员变量前面加上static class Person{ static int i; //静态成员变量 ...
- uva 11538 Chess Queen<计数>
链接:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&am ...
- 安装MySQL的心得
1.去官网上下载适合自己电脑的安装包,最好在网上查查教程起码知道自己应该怎么下载,下载哪一个. 2.我遇到的问题不多:<1>.没在bin目录下安装,启动数据库时出现错误2:<2> ...
- sql server 小记——分区表
我们知道很多事情都存在一个分治的思想,同样的道理我们也可以用到数据表上,当一个表很大很大的时候,我们就会想到将表拆 分成很多小表,查询的时候就到各个小表去查,最后进行汇总返回给调用方来加速我们的查询速 ...
- JVM学习总结一——内存模型
JVM是java知识体系的基石之一,任何一个java程序的运行,都要借助于他.或许对于我这种初级程序员而言,工作中很少有必要刻意去关注JVM,然而如果能对这块知识有所了解,就能够更清晰的明白程序的运行 ...
- Go语言示例-函数返回多个值
Go语言中函数可以返回多个值,这和其它编程语言有很大的不同.对于有其它语言编程经验的人来说,最大的障碍不是学习这个特性,而是很难想到去使用这个特性. 简单如交换两个数值的例子: package mai ...
- MySQL 触发器简单实例
~~语法~~ CREATE TRIGGER <触发器名称> --触发器必须有名字,最多64个字符,可能后面会附有分隔符.它和MySQL中其他对象的命名方式基本相象.{ BEFORE | ...