NOIP2000 提高组 题解

No 1. 进制转换

https://www.rqnoj.cn/problem/295

水题

对于n和基数r, 每次用n mod r, 把余数按照逆序排列

注意 mod后余数必须为正

 int n,r;
 ]={','A','B','C','D','E','F','G','H','I','J'};

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

     while(cin>>n>>r)
     {
         cout<<n;

         string ans="";

         cout<<'=';

         int t=n;

         )
         {
             ;
             x=t%r;
             ) x=x-r;

             ans=a[x]+ans;
             t=(t-x)/r;
         }

         cout<<ans<<'('<<"base"<<r<<')'<<endl;
     }

     ;
 }

No 2. 乘积最大

  https://www.rqnoj.cn/problem/311

简单dp

预处理出s中的s.substr(i,j)

dp(i,j) 为前i个字符中用上k个乘号的种类数

dp[i][j]=max(dp[i][j],dp[k][j-1]*f[k+1][i]) 其中k是用于枚举最后一个乘号的位置

 ][];
 string s;
 long long n,m;
 ][];

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

     cin>>n>>m;

     cin>>s;

     ;i<n;i++)
     {
         ;
         for(long long j=i;j<n;j++)
         {
             num=num*+s[j]-';
             f[i+][j+]=num;
         }
     }

     ;i<=n;i++)
     {
         dp[i][]=f[][i];
     }

     ;i<=n;i++)
     {
         ;j<i;j++)
         {
             for(long long k=j;k<i;k++)
             {
                 dp[i][j]=max(dp[i][j],dp[k][j-]*f[k+][i]);
             }
         }
     }

     cout<<dp[n][m]<<endl;

     ;
 }

No 3.方格取数

https://www.rqnoj.cn/problem/314

简单的一个双线程dp 用贪心也可以

我感觉写两个dp好写多了

不过这样写代码短

 ][]= {},f[][][]= {},temp,n;

 void init()
 {
     int x,y;
     cin>>n;
     while(cin>>x>>y>>temp)
     {
         if(x)s[x][y]=temp;
         else break;
     }
 }

 int ty(int step,int x)
 {
     );
 }

 int max(int a,int b,int c,int d)
 {
     int x,y;
     x=a>b?a:b;
     y=c>d?c:d;
     return x>y?x:y;
 }

 int main()
 {
     int i,j,k,maxn;

     init();

     ; i<=*n-; i++)
         ; j<=n; j++)
             ; k<=n; k++)
             {
                 if (j>i) continue;
                 if (k>i) continue;
                 ][j-][k],f[i-][j][k-],f[i-][j][k],f[i-][j-][k-])+s[j][ty(i,j)];
                 ][j-][k],f[i-][j][k-],f[i-][j][k],f[i-][j-][k-])+s[j][ty(i,j)]+s[k][ty(i,k)];
             }

     cout<<f[*n-][n][n]<<endl;
     ;
 }

No 4.单词接龙

https://www.rqnoj.cn/problem/608

dfs+判断字符串能否首尾相连

判断字符串能否首尾相连用预处理也行,但我觉得没必要

dfs时记录一下长度和字符串使用次数即可

 ],ans;
 ][];

 void readdata()
 {
     cin>>n;
     ; i<=n; i++)
     {
         cin>>s[i];
     }

     cin>>st;

     ; i<=n; i++)
     {
         t[i]=;
     }
 }

 int check(int q,int w)
 {
     int x=strlen(s[q]),y=strlen(s[w]);

     ;

     ; i>; i--)
     {
         ok=;
         for(int j=i; j<x; j++)
         {
             ) continue;

             ok=;
         }

         ) return i;
     }

     ;
 }

 void dfs(int k,int l)
 {
     int x;

     ans=max(ans,l);

     ; i<=n; i++)
     {
         x=check(k,i);

         &&x>)
         {
             t[i]--;

             dfs(i,strlen(s[i])-strlen(s[k])+l+x);

             t[i]++;
         }
     }
 }

 void work()
 {
     ; i<=n; i++)
     {
         ]==st)
         {
             t[i]--;

             dfs(i,strlen(s[i]));

             t[i]++;
         }
     }

     cout<<ans<<endl;
 }

 int main()
 {
     readdata();
     work();

     ;
 }

The End

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

  1. NOIP 2014 提高组 题解

    NOIP 2014 提高组 题解 No 1. 生活大爆炸版石头剪刀布 http://www.luogu.org/problem/show?pid=1328 这是道大水题,我都在想怎么会有人错了,没算法 ...

  2. NOIP 2001 提高组 题解

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

  3. noip 2016 提高组题解

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

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

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

  5. noip 2014 提高组初赛

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

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

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

  7. noip2010提高组题解

    NOIP2010提高组题解 T1:机器翻译 题目大意:顺序输入n个数,有一个队列容量为m,遇到未出现元素入队,求入队次数. AC做法:直接开1000的队列模拟过程. T2:乌龟棋 题目大意:有长度为n ...

  8. 【NOIP2018】提高组题解

    [NOIP2018]提高组题解 其实就是把写过的打个包而已 道路铺设 货币系统 赛道修建 旅行 咕咕咕 咕咕咕

  9. 最优贸易 NOIP 2009 提高组 第三题

    题目描述 C 国有 n 个大城市和 m 条道路,每条道路连接这 n 个城市中的某两个城市.任意两个 城市之间最多只有一条道路直接相连.这 m 条道路中有一部分为单向通行的道路,一部分 为双向通行的道路 ...

随机推荐

  1. 学习Java绝对要懂的,Java编程中最常用的几种排序算法!

    今天给大家分享一下Java中几种常见的排序算法的Java代码 推荐一下我的Java学习羊君前616,中959,最后444.把数字串联起来!     ,群里有免费的学习视频和项目给大家练手.大神有空时也 ...

  2. Hugo快速搭建Blog

    以往我们搭建blog要么学习一个编程语言+Web开发框架,要么使用现成的blog系统(如WordPress).其实我们还可以使用Hugo.Hugo是由Go语言实现的静态网站生成器,它不需要数据库,所以 ...

  3. 由于IPv6导致的iOS应用发布失败,是否该怪Azure?

    IPv6已经被越来越广泛的支持了,尤其是苹果强制要求iOS (确切的说是iOS 9以及后续版本)应用必须支持IPv6之后(官方宣布),更将进一步推动IPv6的使用. 不过苹果应用作为客户端强制要求IP ...

  4. 前端解读Webview

    作为盛行已久的开发方式,Hybrid的相关介绍已经是相当普遍了.不过看到博客园里基本上都是从android或者ios的角度来讲解的,对于h5的前端来说看起来只能是一直半解.感觉有必要从前端的角度来理解 ...

  5. Building Apps for Windows 10 on LattePanda–Jump Start

    1.引言 目前来看,LattePanda应该是最小的运行Full Windows 10系统的开发板了(注意,不是Windows 10 for Mobile,也不是Windows 10 IoT系列,而是 ...

  6. Elasticsearch学习随笔(二)-- Index 和 Doc 查询新建API总结

    本文着重总结Elasticsearch的常见API了,进行分析. Index API 初始化Index,设置shards和replica PUT http://localhost:9200/firew ...

  7. 64位Win10系统安装Mysql5.7.11

    最近在装了64位Win10系统的mac book笔记本上用mysql-installer-community-5.7.11.0安装Mysql5.7.11,在配置mysql server时老是卡住,报错 ...

  8. DELPHI XE5安装

    1.安装XE5 2. HNFJ-DPADCW-BDWCFU-FPNN QDF4-CTSDHV-RDFCFE-FEAN HNFK-BCN8NN-78N53D-H4RS 破解补丁使用方法: (1).复制压 ...

  9. 优雅的封装ajax,含跨域

    之前写过一篇 先定一个小目标,自己封装个ajax,是基于原生js的,也就是jquery中ajax的简化版本实现的思路.众所周知,jquery的ajax是项目中最常用的请求后台的方式,也算是封装的很完美 ...

  10. js实现图片旋转、模板文件查看图片大图之记录篇[二]

    一个小小的前端需求送给大家,使用js实现图片旋转,并且点击图片能够实现规定格式的大图. 主要使用的是jQuery的delegate()方法实现图片旋转,该方法主要的功能就是给某个组件绑定一个或一组事件 ...