嵊州普及Day4T4
题意:求最长上升序列长度和方案数。
思路:经典DP,不需什么别的东西,加一个数组储蓄程序数即可,原题300000可能N2会有问题,但问题不大。
见代码:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
int n,type,q,a[],flag,b[],c[],sum;
int main()
{
freopen("hamon.in","r",stdin);
freopen("hamon.out","w",stdout);
cin>>n>>type;
for(int i=;i<=n;i++)
{
c[i]=b[i]=;
cin>>a[i];
q=;
for(int j=;j<i;j++)
{
if(a[j]<a[i])
{
if(q!=)
if(b[j]==b[i]-)
c[i]+=c[j];
if(b[j]>=b[i])
{
if(b[j]>b[i])
{
c[i]=c[j];
b[i]=b[j];
}
if(b[j]==b[i])
{
c[i]=c[j];
b[i]=b[j]+;
}
q=;
} }
}
}
for(int i=;i<=n;i++)
{
if(b[i]>b[flag])
{
flag=i;
}
}
cout<<b[flag]<<endl;
if(type==)
{
for(int i=;i<=n;i++)
if(b[i]==b[flag])
sum+=c[i];
cout<<sum%;
}
return ;
}
下面是悔恨时间。
不开long long毁一生!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
因为方案数很大,题中说要%123456789,一不小心没开long long
好气啊!!!
见代码*2:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
int n,type,q,a[],flag,b[];
long long c[],sum;
int main()
{
freopen("hamon.in","r",stdin);
freopen("hamon.out","w",stdout);
cin>>n>>type;
for(int i=;i<=n;i++)
{
c[i]=b[i]=;
cin>>a[i];
q=;
for(int j=;j<i;j++)
{
if(a[j]<a[i])
{
if(q!=)
if(b[j]==b[i]-)
c[i]+=c[j];
if(b[j]>=b[i])
{
if(b[j]>b[i])
{
c[i]=c[j];
b[i]=b[j];
}
if(b[j]==b[i])
{
c[i]=c[j];
b[i]=b[j]+;
}
q=;
} }
}
}
for(int i=;i<=n;i++)
{
if(b[i]>b[flag])
{
flag=i;
}
}
cout<<b[flag]<<endl;
if(type==)
{
for(int i=;i<=n;i++)
if(b[i]==b[flag])
sum+=c[i];
cout<<sum%;
}
return ;
}
给我一个巨大的教训。
好题哉!!!
嵊州普及Day4T4的更多相关文章
- 嵊州普及Day1T2
题意:走迷宫.求走到a[n][n]需要多久. 考场上想的dfs,听老师说最多50分.代码懒得码了,知道是走迷宫就好. 正解:bfs,时间复杂度O(n). 见代码: #include<iostre ...
- 嵊州普及Day6T3
题意:n个点,对于q个询问,有t秒及一个矩形的范围.在此矩形内的数每秒加1,若等于c,则下一秒变为0. 思路:t可能很大,%c+1就可以了.然后一个一个加起来就可以了. 见代码: #include&l ...
- 嵊州普及Day6T1
题意:有一个矩形,由正负整数构成.一个位子的魅力值为相邻的格子,若与邻格同号则减去绝对值,若异号则加上绝对值. 思路:一个格子一个格子计算即可,没什么好说的. 见代码: #include<ios ...
- 嵊州普及Day5T4
题意:两个1,每次可将一个*k,一个*K2,n个问题,问能否达成x,y? 思路:只有将x,y相乘为3次方时,才可能.并且相乘的三次方一定要是x,y的因子. 下面证明:3次方易证,因为对每个k,都会乘三 ...
- 嵊州普及Day5T2
题意:将(w,h)的纸条折成(W,H),最少需几步. 思路:横竖互不干扰,然后最多可折int型一半,拿个函数判断两次比较即可,然后折不了的条件是需要的矩形大于给的矩形. 见代码: #include&l ...
- 嵊州普及Day5T1
题意:有n个商店,自家商店的定价不可高于任何一家商店定价,求自家商店最高定价. 思路:拿个变量打擂台即可,不用解释太多. 见代码: #include<iostream> #include& ...
- 嵊州普及Day4T2
题意:有一个单行走廊,每回合第ai个展柜会冒出来一只鬼,右边尽头有一个人间大炮和向最左传送门(费用均1金币),你需要每回合将所有鬼交换展柜,全部至最右,问若从一到n所有回合结束是需多少金币可射死所有鬼 ...
- 嵊州普及Day4T1
题意:从n个数中选出k个数,使他们任意两数之差都等于m. 思路:任意差值都等于m,不就等价于k个数模m余数相同吗? 然后桶排储蓄一下各数余数即可. 见代码: #include<iostream& ...
- 嵊州普及Day3T2
题意:对于n数列的全排列,有多少种可能,是每项前缀和不能整除3.输出可能性%1000000000037. 思路:全部模三,剩余1.2.0,1.2可这样排:1.1.2.1.2.1.2.……2或2.2.1 ...
随机推荐
- Kubernetes的控制器之Deployment的定义
Deploy 的控制器定义参数介绍 [root@master manifests]# kubectl explain deploy KIND: Deployment VERSION: extensio ...
- byte的取值范围
byte b = Byte.MAX_VALUE; b+=1; System.out.println(b); //输出为-128 取值范围为[-128 - 127] 解析: ...
- AOP统一日志打印处理
在日常开发工作中,我们免不了要打印很多log.而大部分需要输出的log又是重复的(例如传入参数,返回值).因此,通过AOP方式来进行日志管理可以减少很多代码量,也更加优雅. Springboot通过A ...
- 解决CentOS7用yum安装软件显示错误:cannot find a valid baseurl for repo: base/7/x86_64
使用yun安装软件时有时会报repo文件的错误,, 主要问题出自于CentOS-Base.repo文件 解决方案:将这个文件后缀名修改使这个文件无效 [root@localhost ~]# cd /e ...
- Linux批量装机(PXE)!
一 .PXE 简介PXE:Pre-boot Excution Environment,预启动执行环境PXE 是由 Intel 公司开发的网络引导技术,工作在 Client/Server 模式,允许客户 ...
- 「AHOI2014/JSOI2014」支线剧情
「AHOI2014/JSOI2014」支线剧情 传送门 上下界网络流. 以 \(1\) 号节点为源点 \(s\) ,新建一个汇点 \(t\),如果 \(u\) 能到 \(v\),那么连边 \(u \t ...
- linux 删除 复制 移动
Linux文件类型 - 普通文件 d 目录文件 b 块设备 c 字符设备 l 符号链接文件 p 管道文件pipe s 套接字文件socket 基名:basename 目录名:dirname basen ...
- Spring boot 启动图片
生成工具:http://patorjk.com/software/taag/#p=testall&h=0&v=0&f=Graffiti&t=Type%20Somethi ...
- 一起探讨Go 语言为什么能成功?
导读 两位创造者Rob Pike和Robert Griesemer一起探讨了Go成功的原因. 常言道,历史不会重演,但总会惊人的相似. 如果您想创建一种编程语言,多向那些有经验的人士学习,他们有很多可 ...
- k短路算法
k短路算法 求解k短路用到了A* 算法,A* ( A star )算法,又称启发式搜索算法,与之相对的,dfs与bfs都成为盲目型搜索:即为带有估价函数的优先队列BFS称为A*算法. 该算法的核心思想 ...