NOIP 2014 提高组 题解

No 1. 生活大爆炸版石头剪刀布

http://www.luogu.org/problem/show?pid=1328

这是道大水题,我都在想怎么会有人错了,没算法,直接模拟,别读错题.

 ][]={{,,,,},
               {,,,,},
               {,,,,},
               {,,,,},
               {,,,,}};

 int n,na,nb;
 ],b[];
 int s1,s2;

 int main()
 {
     ios_base::sync_with_stdio();

     cin>>n>>na>>nb;

     ;i<=na;i++)
     {
         cin>>a[i];
     }

     ;i<=nb;i++)
     {
         cin>>b[i];
     }

     ,f2=;

     ;i<=n;i++)
     {
         f1++;
         f2++;
         ;
         ;
         ) s1++;
         ) s2++;
     }

     cout<<s1<<' '<<s2<<endl;

     ;
 }

No 2. 联合权值

http://www.luogu.org/problem/show?pid=1351

同样是水题,用加法结合律.

首先,距离为2的两点,必有一个节点与他们都相连.

第一个要求最大值,对于每个点,预处理出相邻的边中权值最大的两条边,枚举每个点,计算这两个值的乘积,求个最大值即可.

第二个,要求距离为2的点对的权值之和,那么,我们先确定某点对中间的那个点,设为p,并预处理出p与其相邻的点距离之和d,则与其相邻的某点q,在中心点为p的距离为二的一条路径上的权值之和为d(q,p)*d(m1,p)+d(q,p)*d(m2,p)+...+d(q,p)*d(mi,p)=d(q,p)*(d-d(q,p)) 其中mi为与p相邻的除q以外的点,共i个.

最后求和即可.

 long long n;
 ;
 ];
 ];
 long long mx;
 long long ans;
 vector<];
 ],m2[];

 int main()
 {
     scanf("%lld",&n);

     ;i<n;i++)
     {
         long long a,b;
         scanf("%lld %lld",&a,&b);
         e[a].pb(b);
         e[b].pb(a);
     }

     ;i<=n;i++)
     {
         scanf("%lld",&w[i]);
     }

     ;i<=n;i++)
     {
         ;j<(long long)e[i].size();j++)
         {
             sum[i]+=w[e[i][j]]%MOD;

             if(w[e[i][j]]>m1[i])
             {
                 m2[i]=m1[i];
                 m1[i]=w[e[i][j]];
             }
             else if(w[e[i][j]]>m2[i])
             {
                 m2[i]=w[e[i][j]];
             }
         }
     }

     ;i<=n;i++)
     {
         mx=max(mx,m1[i]*m2[i]);
     }

     printf("%lld ",mx);

     ;i<=n;i++)
     {
         ;j<(long long)e[i].size();j++)
         {
             ans=ans+(w[e[i][j]])*(sum[i]-w[e[i][j]]);
             ans=ans%MOD;
         }
     }

     printf("%lld\n",ans);

     ;
 }

No 3. 飞扬的小鸟

http://www.luogu.org/problem/show?pid=1941

dp

dp

dp

其实这题真心不难

不明白为何有许多人不会做........

我们用dp(i,j)表示鸟儿飞到第i根柱子的j高度处所用的最少跳跃步数.

Obviously,不跳,摔落比较好,所以先处理它.

明显的,dp[i+1][j-y[i]]=min(dp[i+1][j-y[i]],dp[i][j]).

当鸟儿跳的时候,要是到顶了不能继续跳,所以要分个类:

1.到顶了

dp[i][m]=min(dp[i][m],dp[i][j]+1)
dp[i+1][m]=min(dp[i+1][m],dp[i][j]+1)

2.没到顶

dp[i][j+x[i]]=min(dp[i][j+x[i]],dp[i][j]+1);
dp[i+1][j+x[i]]=min(dp[i+1][j+x[i]],dp[i][j]+1);

于是就可以写程序了...

 ][];
 ],r[];
 ];
 ],y[];
 int ans;
 int n,m,k;

 int main()
 {
     ios_base::sync_with_stdio();

     cin>>n>>m>>k;

     ;i<;i++)
     {
         l[i]=;
         r[i]=m;
     }

     ;i<n;i++)
     {
         cin>>x[i]>>y[i];
     }

     ;i<k;i++)
     {
         int t1,t2,t3;
         cin>>t1>>t2>>t3;

         l[t1]=t2+;
         r[t1]=t3-;
         has[t1]=;
     }

     ;i<=n;i++)
     {
         has[i]+=has[i-];
     }

     ;i<=n;i++)
     {
         ;j<=m;j++)
         {
             dp[i][j]=inf;
         }
     }

     ;i<=n;i++)
     {
         ;j<=m;j++)
         {
             dp[i][j]=inf;
         }

         for(int j=l[i];j<=r[i];j++)
         {
             if(dp[i][j]<inf)
             {
                 ans=i;

                 if(j>y[i])
                 {
                     dp[i+][j-y[i]]=min(dp[i+][j-y[i]],dp[i][j]);
                 }
             }
         }

         for(int j=l[i];j<=m;j++)
         {
             if(dp[i][j]<inf)
             {
                 if(m<j+x[i])
                 {
                     dp[i][m]=min(dp[i][m],dp[i][j]+);
                     dp[i+][m]=min(dp[i+][m],dp[i][j]+);
                 }
                 else
                 {
                     dp[i][j+x[i]]=min(dp[i][j+x[i]],dp[i][j]+);
                     dp[i+][j+x[i]]=min(dp[i+][j+x[i]],dp[i][j]+);
                 }
             }
         }
     }

     if(ans==n)
     {
         ans=inf;

         for(int i=l[n];i<=r[n];i++)
         {
             ans=min(ans,dp[n][i]);
         }

         cout<<<<endl<<ans<<endl;
     }
     else
     {
         cout<<<<endl<<has[ans]<<endl;
     }

     ;
 }

先写day1 以后有时间再写day 2.........


NOIP 2014 提高组 题解的更多相关文章

  1. noip 2014 提高组初赛

    noip 2014 提高组初赛 一. TCP协议属于哪一层协议( ) A. 应用层 B. 传输层 C. 网络层 D. 数据链路层 B TCP(传输控制协议) 若有变量int a; float: x, ...

  2. NOIP 2001 提高组 题解

    NOIP 2001 提高组 题解 No 1. 一元三次方程求解 https://vijos.org/p/1116 看见有人认真推导了求解公式,然后猥琐暴力过的同学们在一边偷笑~~~ 数据小 暴力枚举即 ...

  3. NOIP 2000 提高组 题解

    NOIP2000 提高组 题解 No 1. 进制转换 https://www.rqnoj.cn/problem/295 水题 对于n和基数r, 每次用n mod r, 把余数按照逆序排列 注意 mod ...

  4. noip 2016 提高组题解

    前几天写的那个纯属搞笑.(额,好吧,其实这个也不怎么正经) 就先说说day2吧: T1:这个东西应该叫做数论吧. 然而我一看到就照着样例在纸上推了大半天(然而还是没有看出来这东西是个杨辉三角) 然后就 ...

  5. noip 2014 提高组 Day 2

    1.无线网络发射器选址 这道题数据范围很小,就直接暴力枚举就好了.为了提高速度,就从每个有公共场所的点枚举周围在(x,y)放无线网路发射器可以增加的公共场所数量,加到一个数组里.所有公共场所都处理完了 ...

  6. NOIP 2014 提高组 Day1

    期望得分:100+100+50=250 实际得分:100+100+50=250 此次NOIP  ZJ省一分数线:500,SD:345 https://www.luogu.org/problem/lis ...

  7. NOIP 2014 提高组 Day2

    期望得分:100+60+30=190 实际得分:70+60+30=160 https://www.luogu.org/problem/lists?name=&orderitem=pid& ...

  8. NOIP 2008提高组第三题题解by rLq

    啊啊啊啊啊啊今天已经星期三了吗 那么,来一波题解吧 本题地址http://www.luogu.org/problem/show?pid=1006 传纸条 题目描述 小渊和小轩是好朋友也是同班同学,他们 ...

  9. [NOIp 1998 提高组]Probelm 2 连接多位数【2011百度实习生笔试题】

    /*====================================================================== [NOIp 1998 提高组]Probelm 2 连接 ...

随机推荐

  1. 关于MATLAB处理大数据坐标文件2017526

    运行六个特征,提高了3分,也就是说以前做的特征已经用完了,穷途末路,依靠以前的特征已经很难取得进步了,提出以下建议 1.测试集曾经运行错误的数据尽早画出图形,并尽可能发现问题并提出特征 2.运行其他程 ...

  2. python网络爬虫之使用scrapy自动爬取多个网页

    前面介绍的scrapy爬虫只能爬取单个网页.如果我们想爬取多个网页.比如网上的小说该如何如何操作呢.比如下面的这样的结构.是小说的第一篇.可以点击返回目录还是下一页 对应的网页代码: 我们再看进入后面 ...

  3. svn客户端的使用

    1 SVN概述 SVN客户端应用集成在右键菜单中: svn服务器有2种运行方式:独立服务器和借助apache运行.两种方式各有利弊,用户可以自行选择: SVN是Subversion的简称,是一个开放源 ...

  4. 基于两种架构的ETL实现及ETL工具选型策略

    企业信息化建设过程中,业务系统各自为政.相互独立造成的"数据孤岛"现象尤为普遍,业务不集成.流程不互通.数据不共享--.这给企业进行数据的分析利用.报表开发等带来了巨大困难.在此情 ...

  5. 15套java架构师、集群、高可用、高可扩 展、高性能、高并发、性能优化Redis、ActiveMQ、Nginx、Mycat、Netty、Jvm大型分布式项目实战视频教程

    * { font-family: "Microsoft YaHei" !important } h1 { color: #FF0 } 15套java架构师.集群.高可用.高可扩 展 ...

  6. workerman例子无法工作

    现象 workerman已经正常启动,但是按照官网写的例子或者下载的demo无法工作,例如页面打不开,socket连接失败等 解决方法 一般这种workerman启动没报错,但是无法打开页面或者无法连 ...

  7. Appcan开发笔记:结合JQuery的$.Deferred()完善批量异步发送

    appcan的 uexXmlHttpMgr.send 或者 appcan.ajax无法同步请求(没有找到这个属性),只能异步,造成循环多次提交时由于延迟或网络堵塞等原因无法同步响应,导致提交顺序混乱, ...

  8. 【Android Developers Training】 82. 序言:传输数据时减少对电池寿命的影响

    注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...

  9. 第二章(jQuery选择器)

    2.1jQuery选择器是什么 1.CSS选择器 选择器 示例 选择器 示例 标签选择器 a{ } p{ } ul{ } ID选择器 #ID{ } 类选择器 .class{ } 群组选择器 td,p, ...

  10. chart.js使用常见问题

    Chart.js是一个简单.面向对象.为设计者和开发者准备的图表绘制工具库. 在使用过程中新手可能会遇到很多问题导致图标无法显示.下面我们来看一下在使用过程中可能会遇到的问题. 刚开始用chart.j ...