乒乓球

模拟

  1. /*By SilverN*/
  2. #include<iostream>
  3. #include<algorithm>
  4. #include<cstring>
  5. #include<cstdio>
  6. #include<cmath>
  7. using namespace std;
  8. const int mxn=;
  9. char s[];
  10. int a[mxn],b[mxn];//11分制胜负计数
  11. int c[mxn],d[mxn];//21分制计数
  12. int main(){
  13. bool flag=;
  14. int i,j;
  15. int r1=,r2=;//比赛局数
  16. while(scanf("%s",s)!=EOF && flag){
  17. int n=strlen(s);
  18. for(i=;i<n;i++){
  19. if(s[i]=='E'){
  20. flag=;
  21. break;
  22. }
  23. if(s[i]=='W'){
  24. a[r1]++;c[r2]++;
  25. if(a[r1]>= && a[r1]-b[r1]>=)r1++;
  26. if(c[r2]>= && c[r2]-d[r2]>=)r2++;
  27. }
  28. if(s[i]=='L'){
  29. b[r1]++;d[r2]++;
  30. if(b[r1]>= && b[r1]-a[r1]>=)r1++;
  31. if(d[r2]>= && d[r2]-c[r2]>=)r2++;
  32. }
  33. }
  34. }
  35. for(i=;i<=r1;i++)printf("%d:%d\n",a[i],b[i]);
  36. cout<<endl;
  37. for(i=;i<r2;i++)printf("%d:%d\n",c[i],d[i]);
  38. printf("%d:%d",c[r2],d[r2]);
  39. return ;
  40. }

数字游戏

DP 枚举分组 f[k组][前i个]=最值

  1. /*By SilverN*/
  2. #include<iostream>
  3. #include<cstdio>
  4. #include<algorithm>
  5. #include<cstring>
  6. #include<cmath>
  7. using namespace std;
  8. int read(){
  9. int x=,f=;char ch=getchar();
  10. while(ch<'' || ch>''){if(ch=='-')f=-;ch=getchar();}
  11. while(ch>='' && ch<=''){x=x*+ch-'';ch=getchar();}
  12. return x*f;
  13. }
  14. int n,m;
  15. int a[];
  16. int smm[];
  17. int fmx[][];
  18. int fmi[][];
  19. int mxans=,minans=1e8;
  20. void dp(int b[]){
  21. memset(fmx,,sizeof fmx);
  22. memset(fmi,0x2f,sizeof fmi);
  23. int i,j;
  24. for(i=;i<=n;i++)smm[i]=smm[i-]+b[i];
  25. for(i=;i<=n;i++){
  26. fmx[i][]=fmi[i][]=(smm[i]%+)%;
  27. }
  28. fmi[][]=fmx[][]=;
  29. int k;
  30. for(k=;k<=m;k++){
  31. for(i=k;i<=n;i++){
  32. for(j=k-;j<i;j++){
  33. fmx[i][k]=max(fmx[i][k],fmx[j][k-]*(((smm[i]-smm[j])%+)%));
  34. fmi[i][k]=min(fmi[i][k],fmi[j][k-]*(((smm[i]-smm[j])%+)%));
  35. }
  36. }
  37. }
  38. mxans=max(mxans,fmx[n][m]);
  39. minans=min(minans,fmi[n][m]);
  40. return;
  41. }
  42. int main(){
  43. n=read();m=read();
  44. int i,j;
  45. for(i=;i<=n;i++){
  46. a[i]=read();
  47. a[n+i]=a[i];
  48. }
  49. for(i=;i<n;i++)dp(a+i);
  50. printf("%d\n%d\n",minans,mxans);
  51. return ;
  52. }

卡塔兰数

C(2*n,n)/(n+1)

  1. /*By SilverN*/
  2. #include<iostream>
  3. #include<cstdio>
  4. #include<algorithm>
  5. #include<cstring>
  6. #include<cmath>
  7. #include<string>
  8. using namespace std;
  9. int n;
  10. long long ans=;
  11. int main(){
  12. int i,j;
  13. scanf("%d",&n);
  14. int ed=n*;
  15. for(i=n+;i<=ed;i++){
  16. ans=ans*i/(i-n);
  17. }
  18. ans/=(n+);
  19. printf("%lld\n",ans);
  20. return ;
  21. }

麦森数

位数直接计算:log(10,2^n)

数字用高精度乘法模拟

  1. #include<iostream>
  2. #include<cstring>
  3. #include<cmath>
  4. #include<cstdio>
  5. using namespace std;
  6. int la;
  7. int t=;
  8. unsigned int n=;//指数
  9. struct node{
  10. int v[];
  11. int s;
  12. }a,b,c;
  13. node multiple(const node a,const node b );
  14. void pbi(node &c,unsigned int n1)//底数 指数
  15. {
  16. if(n1==||n1==){
  17. c.s=;
  18. c.v[]=n1+;
  19. return;
  20. }
  21. pbi(c,n1/);
  22. c=multiple(c,c);
  23. if(n1%==){
  24. b.s=;
  25. b.v[]=;
  26. c=multiple(b,c);
  27. }
  28. }
  29.  
  30. node multiple(const node a,const node b ){ //高精度乘法部分
  31. int i,j,x=;
  32. if(a.s==&&a.v[]==)return a;
  33. if(b.s==&&b.v[]==)return b;
  34. const int L=;
  35. node c1={};
  36. for(i=;i<L && i<a.s;i++){
  37. for(j=;j<L && j<b.s;j++){
  38. c1.v[i+j]+=a.v[i]*b.v[j];
  39. c1.v[i+j+]+=c1.v[i+j]/;
  40. c1.v[i+j]%=;
  41. }
  42. c1.s=i+j;
  43. if(c1.v[i+j]!=)c1.s++;
  44. }
  45. if(c1.s>) c1.s=;
  46. return c1;
  47. }
  48. int main(){
  49. int i;
  50. cin>>n;
  51. int p=ceil(n*log10());//位数
  52. printf("%d\n",p);
  53. pbi(c,n);
  54. c.v[]-=;
  55. if(c.s>) c.s=;
  56. for (int i=;i>=;i--)//mx
  57. {
  58. printf("%d",c.v[i]);
  59. if (i%==)//50位的倍数时回车
  60. cout<<endl;
  61. }
  62. return ;
  63. }

/*By SilverN*/#include<iostream>#include<cstdio>#include<algorithm>#include<cstring>#include<cmath>usingnamespacestd; int read(){ int x=0,f=1;char ch=getchar(); while(ch<'0' || ch>'9'){if(ch=='-')f=-1;ch=getchar();} while(ch>='0' && ch<='9'){x=x*10+ch-'0';ch=getchar();} return x*f; } int n,m; int a[120]; int smm[120]; int fmx[120][20]; int fmi[120][20]; int mxans=0,minans=1e8; void dp(int b[]){ memset(fmx,0,sizeof fmx); memset(fmi,0x2f,sizeof fmi); int i,j; for(i=1;i<=n;i++)smm[i]=smm[i-1]+b[i]; for(i=1;i<=n;i++){ fmx[i][1]=fmi[i][1]=(smm[i]%10+10)%10; } fmi[0][0]=fmx[0][0]=1; int k; for(k=2;k<=m;k++){ for(i=k;i<=n;i++){ for(j=k-1;j<i;j++){ fmx[i][k]=max(fmx[i][k],fmx[j][k-1]*(((smm[i]-smm[j])%10+10)%10)); fmi[i][k]=min(fmi[i][k],fmi[j][k-1]*(((smm[i]-smm[j])%10+10)%10)); } } } mxans=max(mxans,fmx[n][m]); minans=min(minans,fmi[n][m]); return; } int main(){ n=read();m=read(); int i,j; for(i=1;i<=n;i++){ a[i]=read(); a[n+i]=a[i]; } for(i=0;i<n;i++)dp(a+i); printf("%d\n%d\n",minans,mxans); return0; }

[NOIP2003] 普及组的更多相关文章

  1. 洛谷 P1045 & [NOIP2003普及组] 麦森数

    题目链接 https://www.luogu.org/problemnew/show/P1045 题目大意 本题目的主要意思就是给定一个p,求2p-1的位数和后500位数. 解题思路 首先看一下数据范 ...

  2. [NOIP2003普及组]麦森数(快速幂+高精度)

    [NOIP2003普及组]麦森数(快速幂+高精度) Description 形如2^P-1的素数称为麦森数,这时P一定也是个素数.但反过来不一定,即如果P是个素数,2^P-1不一定也是素数.到1998 ...

  3. 【转】[NOIP2003普及组]麦森数

    来源:http://vivid.name/tech/mason.html 不得不纪念一下这道题,因为我今天一整天的时间都花到这道题上了.因为这道题,我学会了快速幂,学会了高精度乘高精度,学会了静态查错 ...

  4. 【动态规划】Vijos P1218 数字游戏(NOIP2003普及组)

    题目链接: https://vijos.org/p/1218 题目大意: 一个N个数的环,分成M块,块内的数求和%10,最后每块地值累乘,求最大和最小. n(1≤n≤50)和m(1≤m≤9)太小了可以 ...

  5. P1045 [NOIP2003 普及组] 麦森数

    题目描述 形如2^P−1的素数称为麦森数,这时P一定也是个素数.但反过来不一定,即如果P是个素数,2^P−1不一定也是素数. 到1998年底,人们已找到了37个麦森数.最大的一个是P=3021377, ...

  6. NOIP2003 普及组 洛谷P1045 麦森数 (快速幂+高精度)

    有两个问题:求位数和求后500位的数. 求位数:最后减去1对答案的位数是不影响的,就是求2p的位数,直接有公式log10(2)*p+1; 求后500位的数:容易想到快速幂和高精度: 1 #includ ...

  7. NOIP2002-2017普及组题解

    虽然普及组一般都是暴力省一,但是有一些题目还是挺难的qwq个人觉得能进TG的题目会在前面打上'*' NOIP2002(clear) #include<bits/stdc++.h> usin ...

  8. NOIP2012 普及组 T3 摆花——S.B.S.

    题目描述 小明的花店新开张,为了吸引顾客,他想在花店的门口摆上一排花,共m盆.通过调查顾客的喜好,小明列出了顾客最喜欢的n种花,从1到n标号.为了在门口展出更多种花,规定第i种花不能超过ai盆,摆花时 ...

  9. NOIP2016普及组复赛解题报告

    提高组萌新,DAY1DAY2加起来骗分不到300,写写普及组的题目聊以自慰. (附:洛谷题目链接 T1:https://www.luogu.org/problem/show?pid=1909 T2:h ...

随机推荐

  1. AJPFX关于JAVA多线程实现的三种方式

    JAVA多线程实现方式主要有三种:继承Thread类.实现Runnable接口.使用ExecutorService.Callable.Future实现有返回结果的多线程.其中前两种方式线程执行完后都没 ...

  2. tcpdump 使用详解——转载

    http://www.cnblogs.com/ggjucheng/archive/2012/01/14/2322659.html 简介 用简单的话来定义tcpdump,就是:dump the traf ...

  3. 激活eclipse自动提示功能

    eclipse设置: Window->Preferences->Java->Editor->Content Assist

  4. 基于jmeter和shell的接口性能自动化

    基于jmeter和shell的接口性能自动化 1. 总体需求 由于性能测试中涉及的查询接口多,版本迭代频繁,版本更新后自动跑一轮查询业务的性能,可以及时发现一些开发修复bug触发的非预期的bug,利用 ...

  5. SEO 第六章

    SEO第六章 本次课程目标: 1.      掌握网站的内链优化 2.      网站的URL优化 一. 网站地图 1. 什么是网站地图? 网站地图也叫站点地图,英文名叫sitemap,指的网站所有内 ...

  6. fork后子进程从哪里开始执行

    子进程和父进程都从调用fork函数的下一条语句开始执行

  7. python基础一 day2

    内容:   3%%s   输出:3%s       后面的全部转义 结果: 如果是因为执行break语句导致循环提前结束,就不会执行else. 单位换算: 编码方式: ascii  unicode u ...

  8. input_shape { dim: 1 dim: 3 dim: 224 dim: 224 }

    http://blog.csdn.net/u010417185/article/details/52619593

  9. 16.04 下修改 ssh 默认端口

    打开/etc/ssh/ssh_config,在Port指令下追加新的端口设置: Port 8888 即允许通过端口 8888 进行 ssh 访问. 打开/etc/ssh/sshd_config,进行同 ...

  10. delphi并行压缩

    real case test MM parallel 4x scalable (i7 6700)(on the newer processors will be linear) I did a sma ...