04day1

无穷的数列

找规律

【问题描述】

有一个无穷序列如下:

110100100010000100000…

请你找出这个无穷序列中指定位置上的数字。

【输入】

第一行一个正整数 N,表示询问次数;接下来的 N 行每行一个正整数 Ai,Ai 表示在序列中的位置。

【解题过程】

找规律就好了。对于一个给定的位置 P,可以发现如果 P 上的数字是 1,那么必然满足 P-1 = x*(x+1)/2,那么判断这个方程是否有整数解即可(开平方取整再乘)。

1 次 AC。

 

方程

动态规划

【问题描述】

【输入】

第一行是 n 和 c。

第二行是 n 个数,分别表示 a1, a2, ..., an。

【输出】

输出解的组数(结果对 999983 取模)。

【解题过程】

一开始真的没思路啊,刚好数学在上排列组合,有个神奇的「隔板法」,差点误入歧途。

然后想到了一个很奇葩的方法,用 f[i] 表示用这个式子组成 i 这个值有几组解,则

f[i] = sum{ f[i-a[j]], 1<=j<=n }

看上去有点道理,然后其实是错的。这种状态转移的方式无法判断重复的情况,比如 b1 取 1,b2 取 1 是可以由两种情况(1, 0 和 0, 1)推过来的,加的时候也就多加了。

然后居然想了将近一个小时才想到正解,我也是醉了。

用 f[i][j] 表示用 a1, a2, ..., ai 来组成 j 有多少组解,则

f[i][j] = f[i-1][j] + f[i-1][j-a[i]], 1<=j<=n

然后如果用上滚动数组的话,最后表现出来的代码与上面那种错误方法几乎完全一样,只是外循环和内循环调换了一下。

然后听到 lzw 大神说无限背包。然后就没有然后了。

1 次 AC。

 

交错匹配

动态规划

【问题描述】

有两排非负整数 A[1..N],B[1..M],如果 A[i]=B[j]=k,那么可以在 A[i]和 B[j]之间连一条线,称为一条 k 匹配,每个数至多连一条线。另外,每个 k 匹配都必须恰好跟一个 r 匹配相交,且 k≠r。现在要求一个最大的匹配数。

例如:以下两行数的最大匹配数为 8.一个数最多只能和一个数连线。

【输入】

输入文件第一行包含两个正整数 n 和 m。

第二行 n 个自然数,表示 a[i]。

第三行 m 个自然数,表示 b[i]。

【数据规模】

30%的数据满足 n,m≤30。

60%的数据满足 n,m≤200。

100%的数据满足 n,m≤1000,0<所有数≤32767。

【解题过程】

看到什么最大匹配的还以为是二分图,吓了一小跳。

然后从数据范围来看几乎可以肯定是 O(mn) 的动态规划。

借鉴 LCS 的状态表示,用 f(i, j) 表示 a1, ..., ai 与 b1, ..., bj 之间的最大匹配数,那么我们只要考虑 ai 与 bj 是否需要进行匹配。如果要进行匹配,那么只要在 bj 的左边找与 ai 匹配的数、在 ai 的左边找与 bj 匹配的数就能保证两个匹配相交。很明显,对于 ai 找 bj 左边距离 bj 最近的那个匹配才可能是最优解,对于 bj 也应该找 ai 左边最近的匹配。这个找匹配的过程我们可以事先进行预处理。用 p(i, j) 表示 ai 在 b1, b2, ..., bj 中离 bj 最近的那个匹配所在的位置,则可以进行递推:

若 ai=bj,则 p(i, j) = j

否则,p(i, j) = p(i, j-1)

然后可以用 q(j, i) 表示 bj 在 a1, a2, ..., ai 中离 ai 最近的那个匹配的位置,递推过程类似。

然后就可以写出状态转移方程了,

f(i, j) = max{ f(q(j, i-1)-1, p(i, j-1)-1), f(i-1, j), f(i, j-1), f(i-1, j-1) }

初始得分 90 分。原因是把递推的嵌套循环范围写错了(这样也能拿 90 分?)。

转载于:https://www.cnblogs.com/lsdsjy/p/3982489.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/575208.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

arraylist扩容是创建新数组吗 java_Java编程之数组扩容

一、背景数组在实际的系统开发中用的越来越少了&#xff0c;我们只有在阅读某些开源项目时才会看到数组的使用。在Java中&#xff0c;数组与List、Set、Map等集合类相比&#xff0c;后者使用起来方便&#xff0c;但是在基本数据类型处理方面&#xff0c;数组还是占优势的&#…

【转】Eclipse+CDT+Gcc编译选项控制

原文地址&#xff1a;http://www.oschina.net/question/4873_19441 如果我们的程序调用动态链接库&#xff0c;当在cdt中运行的时候&#xff0c;可以通过run-->enviroment-->添加LD_LIBRARY_PATH 环境变量来设置查找动态链接库文件的路径。但是在运行的时候&#xff0c;程…

apt ubuntu 指定ipv4_macOS 下使用 Docker 搭建 ubuntu 环境

学习网络开发过程中不想“污染”macOS&#xff0c;考虑到之后部署网络应用主要是与linux打交道&#xff0c;所以安装了 ubuntu 虚拟机以满足短期的知识学习需求。十里安装了 ubuntu 虚拟机&#xff0c;一般就是在 mac 中 ssh 连接 ubuntu 虚拟机在终端下进行操作学习&#xff0…

java中static关键字简介

static静态关键字&#xff1a; static关键字可以修饰成员变量和成员方法&#xff0c;被修饰的成员是属于类的&#xff0c;而不是简简单单的属于某个对象&#xff0c;也就是说可以不用通过对象调用&#xff0c;而是通过类直接调用。 类变量&#xff08;静态变量&#xff09;&a…

[WCF编程]10.操作:回调操作

一、回调操作概述 WCF支持服务将调用返回给它的客户端。在回调期间&#xff0c;许多方面都将颠倒过来&#xff1a;服务将成为客户端&#xff0c;客户端将编程服务。回调操作可以用在各种场景和应用程序中&#xff0c;但在涉及事件或者服务发生时间需要通知客户端时&#xff0c;…

float去掉小数点之后_float类型的存储方式

在c语言中float函数是单精度的。它在内存中以二进制的形式存储。分为符号位&#xff0c;阶码与尾数三部分。 符号位最为简单&#xff0c;如果你存储的是正数那么符号数就是0。如果是负数&#xff0c;则为1。下面&#xff0c;我以13.625为例说明阶码与尾数的表示方法。首先&…

idea 2020.2 如何设置classpath_开发属于自己的第一款IDEA插件!

作者&#xff1a;木杉 http://imushan.com/写Java代码的时候&#xff0c;经常会涉及到重复性的操作&#xff0c;这个时候就会想要是有这样一个插件就好了&#xff0c;如果是大家都会遇到的场景&#xff0c;IDE或许已经提供了&#xff0c;再不然也有可能有人编写了相关的插件。要…

java中Arrays类和Math类常用API简介

Arrays类&#xff1a; java.util.Arrays是一个与数组相关的工具类&#xff0c;提供了许多静态方法对数组进行操作&#xff0c;直接通过类点出来使用&#xff0c;无需创建对象。 // 1.Arrays类存在与java.util下&#xff0c;需要导包&#xff1a; import java.util.Arrays; pu…

按15分钟取数据_Python爬取猫眼电影《飞驰人生》4万多条评论并对其进行数据分析...

前言文的文字及图片来源于网络,仅供学习、交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理。作者&#xff1a; Yura不说数据说 &#xff0c;PYuraLPS&#xff1a;如有需要Python学习资料的小伙伴可以加点击下方链接自行获取http://note.youdao.c…

UI设计

摘要 源于ajlr项目的验收&#xff0c;过程中ui的设计被屡次提到。所以就有了这样一个思考&#xff0c;什么是ui设计&#xff1f;对于开发人员来说&#xff0c;ui设计是否很重要&#xff1f;以及如何来进行ui设计&#xff1f; ui设计&#xff1f; User Interface&#xff0c;简称…

Java中继承、this关键字、super关键字

继承: 概述&#xff1a;当多个类中存在相同属性和行为时&#xff0c;将这些相同的内容抽取到单独一个类中&#xff0c;那么多个类无需再定义这些属性和行为&#xff0c;只要继承抽离出来的这个类即可。 子类&#xff1a;当某个类继承了另一个类的时候&#xff0c;可以把这个某…

java中抽象类,abstract关键字

抽象类&#xff1a;java语法规定&#xff0c;包含抽象方法的类为抽象类。 abstract关键字&#xff1a;abstract用来定义抽象方法和抽象类&#xff0c;定义抽象方法格式为&#xff1a;abstract修饰方法&#xff0c;并去掉大括号&#xff0c;直接以封号结束&#xff1b;定义抽象…

c++获取当前时间戳_python开发:python时间模块的使用

前言&#xff1a;今天元宵节&#xff0c;祝福大家元宵节快乐。今天在元宵节给各位朋友分享一下python时间模块。我们在开发中经常会与时间打交道&#xff0c;如&#xff1a;获取事件戳&#xff0c;时间戳的格式化等&#xff0c;这里简要记录一下python操作时间的方法。ython中常…

Linux重新编译内核指南

Linux的一个重要的特点就是其源代码的公开性&#xff0c;全世界任何一个软件工程师都可以将自己认为优秀的代码加入到其中&#xff0c;由此引发的一个明显的好处就是Linux修补漏洞的快速以及对最新软件技术的利用。而Linux的内核则是这些特点的最直接的代表。      为什么…

python 获取向上两级路径_Python学习第171课--相对路径和绝对路径

【每天几分钟&#xff0c;从零入门python编程的世界&#xff01;】这节我们补充2个概念&#xff1a;相对路径和绝对路径。●绝对路径就像一棵大树一样&#xff0c;从它的根开始&#xff0c;往上会有大的枝干&#xff0c;在大的枝干上面又会有小一点的树枝&#xff0c;小树枝上面…

Java接口、implements关键字、接口中抽象方法,默认方法,静态方法,私有方法,常量、final关键字

接口&#xff1a; 接口是Java语言中一种引用类型&#xff0c;是方法的集合&#xff0c;如果说类的内部封装了成员变量、构造方法和成员方法&#xff0c;那么 接口的内部主要就是封装了方法&#xff0c;包含抽象方法&#xff08;JDK 7及以前&#xff09;&#xff0c;默认方法和…

百度热力图颜色说明_大数据下的龙港、鳌江人口热力图

大数据下的龙港、鳌江人口热力图--趋势显示&#xff0c;人口逐步集中于区域中心地区与城市 2020-08-25 大数据(big data)&#xff0c;是指无法在一定时间内用常规软件工具对其内容进行抓取、管理和处理的数据集合。大数据有五大特点&#xff0c;即大量(Volume)、高速(Velocity)…

python 显示图片matplotlib_Python OpenCV ——Matplotlib显示图片

Color image loaded by OpenCV is in BGR mode.But Matplotlib displays in RGB mode.So color images will not be displayed correctly in Matplotlib if image is read with OpenCV.Please see the exercises for more details.(引自文档)import numpy as npimport cv2from …

什么是Spring?Spring是什么?

Spring概述&#xff1a; Spring是一个开源框架&#xff0c;是为了解决企业应用程序开发复杂性而开发的。 从简单性、可測试性和松耦合的角度而言&#xff0c;不论什么java应用都能够从Spring中受益。 简而言之&#xff0c;Spring就是一个轻量级的控制反转&#xff08;IOC&#…