题目链接:http://files.cnblogs.com/files/candy99/%E9%A2%98%E7%9B%AE1117.pdf


A

n个等比数列求和公式(都感觉数列忘光了)

%1e9+7要用逆元

  1. #include <iostream>
  2. #include <cstdio>
  3. #include <algorithm>
  4. #include <cstring>
  5. #include <cmath>
  6. using namespace std;
  7. typedef long long ll;
  8. const int MOD=1e9+;
  9. int n,m;
  10. ll powMod(ll a,int b){
  11. ll ans=;
  12. for(;b;b>>=,a=(a*a)%MOD)
  13. if(b&) ans=(ans*a)%MOD;
  14. return ans;
  15. }
  16. void exgcd(ll a,ll b,ll &d,ll &x,ll &y){
  17. if(b==) {d=a;x=;y=;}
  18. else {exgcd(b,a%b,d,y,x);y-=(a/b)*x;}
  19. }
  20. ll inv(ll a,ll n){
  21. ll d,x,y;
  22. exgcd(a,n,d,x,y);
  23. return d==?(x+n)%n:-;
  24. }
  25. int main(){
  26. scanf("%d%d",&n,&m);
  27. ll ans=m;
  28. for(int i=;i<=n;i++){
  29. ll p=powMod(i,m);
  30. ll tmp=i*(p-)%MOD*inv(i-,MOD)%MOD;
  31. ans=(ans+tmp)%MOD;
  32. }
  33. printf("%lld",ans);
  34. }

B

poj two缩水版,连直径都不用求,求从1开始最长路径

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstring>
  4. #include<algorithm>
  5. using namespace std;
  6. const int N=5e4+;
  7. int read(){
  8. char c=getchar();int x=,f=;
  9. while(c<''||c>''){if(c=='-')f=-; c=getchar();}
  10. while(c>=''&&c<=''){x=x*+c-''; c=getchar();}
  11. return x*f;
  12. }
  13. int n,u,v,w;
  14. struct edge{
  15. int ne,v,w;
  16. }e[N<<];
  17. int h[N],cnt=;
  18. void ins(int u,int v,int w){
  19. cnt++;
  20. e[cnt].v=v; e[cnt].w=w; e[cnt].ne=h[u]; h[u]=cnt;
  21. cnt++;
  22. e[cnt].v=u; e[cnt].w=w; e[cnt].ne=h[v]; h[v]=cnt;
  23. }
  24. int f[N],sum=;
  25. void dp(int u,int fa){
  26. for(int i=h[u];i;i=e[i].ne){
  27. int v=e[i].v,w=e[i].w;
  28. if(v==fa) continue;
  29. dp(v,u);
  30. f[u]=max(f[u],f[v]+w);
  31. }
  32. }
  33. int main(){
  34. n=read();
  35. for(int i=;i<=n-;i++) u=read(),v=read(),w=read(),ins(u,v,w),sum+=w*;
  36. dp(,);
  37. printf("%d",sum-f[]);
  38. }

C

【问题背景】

zhx和妹子们玩数数游戏。

【问题描述】

仅包含4或7的数被称为幸运数。

一个序列的子序列被定义为从序列中删去若干个数,剩下的数组成的新序列。两个子序列被定义为不同的当且仅当其中的元素在原始序列中的下标的集合不相等。对于一个长度为N的序列,共有2^N个不同的子序列。(包含一个空序列)。

一个子序列被称为不幸运的,当且仅当其中不包含两个相同的幸运数。

对于一个给定序列,求其中长度恰好为K的不幸运子序列的个数,答案mod 10^9+7输出。

【输入格式】

第一行两个正整数N,K,表示原始序列的长度和题目中的K。

接下来一行N个整数ai,表示序列中第i个元素的值。

【输出格式】

仅一个数,表示不幸运子序列的个数。(mod 10^9+7)

【样例输入】

3 2

1 1 1

【样例输出】

3

【样例输入】

4 2

4 7 4 7

【样例输出】

4

【样例解释】

对于样例1,每个长度为2的子序列都是符合条件的。

对于样例2,4个不幸运子序列元素下标分别为:{1, 2}, {3, 4}, {1, 4}, {2, 3}。注意下标集{1, 3}对应的子序列不是“不幸运”的,因为它包含两个相同的幸运数4.


卡读题啊

是序列不是字符串,只含4或7是幸运数字,有两个相同的幸运数字是不幸运序列

搜了题解

幸运数字大约2^10个,可以预处理出来,直接构造不幸运数列

ans=Σ(0<=i<=k) C(n1,i)*f(n2,k-i)

n1是不幸运数字数量,n2是幸运数字数量

f[i][j]表示前i个幸运数字选j个的方案数,一个幸运数字只能选一个,所以需要DP

组合数也需要逆元

PS:构造幸运数字的dfs少写了一层。。。。。。。查了好久

  1. #include <iostream>
  2. #include <cstdio>
  3. #include <algorithm>
  4. #include <cstring>
  5. #include <cmath>
  6. using namespace std;
  7. typedef long long ll;
  8. const int N=1e5+,M=1e3+;
  9. const int MOD=1e9+;
  10. inline int read(){
  11. char c=getchar();int x=,f=;
  12. while(c<''||c>''){if(c=='-')f=-;c=getchar();}
  13. while(c>=''&&c<=''){x=x*+c-'';c=getchar();}
  14. return x*f;
  15. }
  16. int n,k,a,n1,n2;
  17. ll luc[M],cnt=,sum[M];
  18. void dfs(int d,ll now){
  19. if(now) luc[++cnt]=now;
  20. if(d==) return;
  21. dfs(d+,now*+);
  22. dfs(d+,now*+);
  23. }
  24. ll f[N],c[N];
  25. void exgcd(ll a,ll b,ll &d,ll &x,ll &y){
  26. if(b==) {d=a;x=;y=;}
  27. else {exgcd(b,a%b,d,y,x);y-=(a/b)*x;}
  28. }
  29. ll inv(ll a,ll n){
  30. ll d,x,y;
  31. exgcd(a,n,d,x,y);
  32. return d==?(x+n)%n:-;
  33. }
  34. void dp(){
  35. f[]=;
  36. for(int i=;i<=cnt;i++) if(sum[i]>=)
  37. for(int j=i;j>=;j--)
  38. f[j]=(f[j]+f[j-]*sum[i]%MOD)%MOD;
  39.  
  40. c[]=;
  41. for(int i=;i<=n1;i++)
  42. c[i]=c[i-]*(n1-i+)%MOD*inv(i,MOD)%MOD;
  43. }
  44. int main(){
  45. n=read();k=read();
  46. n1=n;
  47. dfs(,);
  48. sort(luc+,luc++cnt);
  49. for(int i=;i<=n;i++){
  50. a=read();
  51. int p=lower_bound(luc+,luc++cnt,a)-luc;
  52. if(luc[p]==a){
  53. sum[p]++; //sum[p]==1 regard as unlucky
  54. if(sum[p]==) n2++,n1-=;
  55. if(sum[p]>) n1--;
  56. }
  57. }
  58. dp();
  59. ll ans=;
  60. for(int i=;i<=k;i++) ans=(ans+c[i]*f[k-i]%MOD)%MOD;
  61. printf("%lld",ans);
  62. }

NOIP复习赛20161117的更多相关文章

  1. NOIP模拟赛20161022

    NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...

  2. contesthunter暑假NOIP模拟赛第一场题解

    contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...

  3. NOIP模拟赛 by hzwer

    2015年10月04日NOIP模拟赛 by hzwer    (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...

  4. 大家AK杯 灰天飞雁NOIP模拟赛题解/数据/标程

    数据 http://files.cnblogs.com/htfy/data.zip 简要题解 桌球碰撞 纯模拟,注意一开始就在袋口和v=0的情况.v和坐标可以是小数.为保险起见最好用extended/ ...

  5. 队爷的讲学计划 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的讲学计划 题解:刚开始理解题意理解了好半天,然后发 ...

  6. 队爷的Au Plan CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的Au%20Plan 题解:看了题之后觉得肯定是DP ...

  7. 队爷的新书 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的新书 题解:看到这题就想到了 poetize 的封 ...

  8. CH Round #58 - OrzCC杯noip模拟赛day2

    A:颜色问题 题目:http://ch.ezoj.tk/contest/CH%20Round%20%2358%20-%20OrzCC杯noip模拟赛day2/颜色问题 题解:算一下每个仆人到它的目的地 ...

  9. CH Round #52 - Thinking Bear #1 (NOIP模拟赛)

    A.拆地毯 题目:http://www.contesthunter.org/contest/CH%20Round%20%2352%20-%20Thinking%20Bear%20%231%20(NOI ...

随机推荐

  1. 【C#公共帮助类】给大家分享一些加密算法 (DES、HashCode、RSA、AES等)

    AES 高级加密标准(英语:Advanced Encryption Standard,缩写:AES),在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准.这个标准用来替代原先的 ...

  2. C#模拟Http请求时出现 基础连接已经关闭 未能为 SSLTLS 安全通道建立信任关系

    //解决方法: //引入命名空间: using System.Security.Cryptography.X509Certificates; using System.Net.Security; // ...

  3. nginx 添加nginx-http-concat模块

    github地址:https://github.com/alibaba/nginx-http-concat/tree/master 简单的描述一下吧,网上说的安装新的模块需要重新编译nginx,具体的 ...

  4. JSTL中的fmt标签小例子

    <%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding= ...

  5. javascript实现下雪效果

    原理: 1.js动态创建DIV,指定CLASS类设置不同的背景图样式显示不同的雪花效果. 2.js获取创建的DIV并改变其top属性值,当下落的高度大于屏幕高后删除该移动div 3.好像不够完善勿喷 ...

  6. Microsoft Visual C++ Compiler for Python

    Visual C++ |CPython ------------------------------------------- 14.0(2015) |3.5 10.0(2010) |3.3, 3.4 ...

  7. GPS各种地图坐标系转换(转载)

    http://my.oschina.net/fankun2013/blog/338100 地图供应商比较多,产生了许多地图坐标.地图坐标正确转换是个问题.在之前开发地图应用的时候发现从WGS84坐标系 ...

  8. eclipse — Failed to load the JNI shared library”……\jvm.dll问题原因以及解决方案

    首先上一张出现问题的图片: 出现这个问题一般是你的jdk和eclipse不是同一位的,比如你的jdk是32位的但是eclipse下载的是64位的就会导致这种问题. 解决方案:把两者都换为32或者64位 ...

  9. iOS开发-UI 从入门到精通(二)

    iOS开发-UI 从入门到精通(二)是对 iOS开发-UI 从入门到精通(一)知识点的巩固,主要以习题练习为主,增强实战经验,为以后做开发打下坚实的基础! ※开发环境和注意事项: 1.前期iOS-UI ...

  10. shell脚步传参

    linux系统除了提供位置参数还提供内置参数,内置参数如下: $# ----传递给程序的总的参数数目 $? ----上一个代码或者shell程序在shell中退出的情况,如果正常退出则返回0,反之为非 ...