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 解题报告的更多相关文章

  1. Codeforces #263 div2 解题报告

    比赛链接:http://codeforces.com/contest/462 这次比赛的时候,刚刚注冊的时候非常想好好的做一下,可是网上喝了个小酒之后.也就迷迷糊糊地看了题目,做了几题.一觉醒来发现r ...

  2. Codeforces Round#320 Div2 解题报告

    Codeforces Round#320 Div2 先做个标题党,骗骗访问量,结束后再来写咯. codeforces 579A Raising Bacteria codeforces 579B Fin ...

  3. Codeforces Round #299 Div2 解题报告

    这场比赛并没有打现场,昨天晚上做了ABCD四道题,今天做掉了E题 以前还没有过切完一场比赛的所有题呢~爽~ A. Tavas and Nafas   Today Tavas got his test ...

  4. codeforces 31C Schedule 解题报告

    题目链接:http://codeforces.com/problemset/problem/31/C 题目意思:给出 n 个 lessons 你,每个lesson 有对应的 起始和结束时间.问通过删除 ...

  5. codeforces 499B.Lecture 解题报告

    题目链接:http://codeforces.com/problemset/problem/499/B 题目意思:给出两种语言下 m 个单词表(word1, word2)的一一对应,以及 profes ...

  6. codeforces 495C. Treasure 解题报告

    题目链接:http://codeforces.com/problemset/problem/495/C 题目意思:给出一串只有三种字符( ')','(' 和 '#')组成的字符串,每个位置的这个字符 ...

  7. codeforces 490B.Queue 解题报告

    题目链接:http://codeforces.com/problemset/problem/490/B 题目意思:给出每个人 i 站在他前面的人的编号 ai 和后面的人的编号 bi.注意,排在第一个位 ...

  8. CodeForces 166E -Tetrahedron解题报告

    这是本人写的第一次博客,学了半年的基础C语言,初学算法,若有错误还请指正. 题目链接:http://codeforces.com/contest/166/problem/E E. Tetrahedro ...

  9. codeforces 489A.SwapSort 解题报告

    题目链接:http://codeforces.com/problemset/problem/489/A 题目意思:给出一个 n 个无序的序列,问能通过两两交换,需要多少次使得整个序列最终呈现非递减形式 ...

随机推荐

  1. VMware虚拟机升级过程中遇到的一点问题

    在将VWware由9.0升级到10.0的过程中,出现如下图的错误:        failed to create the requested registry key Key:Installer e ...

  2. Android开发之Source无法覆写public void onClick(View v)

    初学Android开发,在为一个按钮[该按钮继承OnClickListener()]写监听时,发现无法在Source中引入public void onClick(View v),当时非常纳闷,平常情况 ...

  3. Java 第二天

    1.不带访问修饰符号的类成员变量默认是friendly(可以同一个包中访问) 2.protected的类成员可以在同一个包及其子类中访问 3.方法中可以定义内部类(如下面的代码),该类只能访问方法中的 ...

  4. Learning Scrapy笔记(七)- Scrapy根据Excel文件运行多个爬虫

    摘要:根据Excel文件配置运行多个爬虫 很多时候,我们都需要为每一个单独的网站编写一个爬虫,但有一些情况是你要爬取的几个网站的唯一不同之处在于Xpath表达式不同,此时要分别为每一个网站编写一个爬虫 ...

  5. 010-python基础-数据类型-字符串操作

    1.移除空白 username.strip() 2.分割 names = "alex,jack,rain" names_1 = names.split(",") ...

  6. openstack的第二天

    今天,在公司测试了还是网络有问题. 但是用了rdo还是成功了~明天就再试试怎么开放端口进来.

  7. LPHW-积累-ex1-6

    Learn Python The Hard Way  ex0  介绍了各个操作系统下python的安装:强调了初学者最好使用简单的编辑器,不要使用IDE环境 ex1 使用 print 输出简单的字符串 ...

  8. WPF 中的字号问题

    用WPF搞打印机真是各种碰壁,尤其是对于我这个没有搞过打印机的人来说,更是遍布神坑T_T. 今天敲代码的时候发现字体的FontSize貌似跟单位也有关系啊,因为打印的时候效果感觉和预期竟然是有着差距的 ...

  9. SQL语句基础之 单表查找

    Sql语句之 单表查询 一.一般查询 1.查看表中的所有记录 以及 所有字段(属性) 语句 : select * from student; 2.只查看某些字段 语句:select sname,sex ...

  10. 多线程报表生成其中报表以pdf形式保存

    设计思路采用生产者消费者模式,生产者生产报表消费者消费报表生成pdf文件其中报表以html形式存储在线程安全列表中.使用到技术有:多线程协作,线程池,线程安全,html 生成pdf. 一.生产者生成h ...