P4882 lty loves 96!

题目背景

众所周知,\(lty\)非常喜欢\(96\)这两个数字(想歪的现在马上面壁去),更甚于复读(人本复)!

题目描述

由于爱屋及乌,因此,\(lty\)对于那些含有\(96\)的数也非常喜欢,而这里的含有不是一般的含有,而是具有以下性质的含有(三条都需要满足):

这个数为一个\(N\)位数,且没有前置零

这个数中至少要出现\(M\)次\(9\)和\(6\)(例:\(986996\)中出现了\(5\)次,\(9\)出现了\(3\)次,\(6\)出现了\(2\)次,共计\(5\)次)

这个数存在任意连续的从高到低三位\(A,B,C\),满足下面任意一条

\(A+B+C\)为\(9\)或\(6\)

\((A^2+B^2)\%C\)为\(9\)或\(6\),如果\(C\)为\(0\),则该条件视为不满足

输入输出格式

输入格式:

一行,两个数\(N\),\(M\)

输出格式:

一个数,表示这样的数的个数

说明

对于10%的数据,\(N<=6\)

对于40%的数据,\(N<=18\)

对于100%的数据,\(N<=50,0<=M<=N\)


人生第一道数位DP

\(dp_{i,j,k,l,q}\)从高到低前\(i\)位第\(i\)位为\(j\),第\(i-1\)位为\(k\),一共有\(l\)个\(6\)或\(9\),是否已经满足条件的方案数

注意前导0,注意要压位高精。


Code:

#include <cstdio>
#include <cstring>
int max(int x,int y){return x>y?x:y;}
struct node
{
int num[20];
node()
{
memset(num,0,sizeof(num));
num[0]=1;
}
node(int i)
{
memset(num,0,sizeof(num));
num[0]=1,num[1]=i;
}
node friend operator +(node n1,node n2)
{
int len=max(n1.num[0],n2.num[0]);
node n3;
n3.num[0]=len;
for(int i=1;i<=len;i++)
{
n3.num[i]+=n1.num[i]+n2.num[i];
n3.num[i+1]=n3.num[i]/10000;
n3.num[i]%=10000;
}
if(n3.num[len+1]) ++n3.num[0];
return n3;
}
}dp[51][10][10][51][2];
int n,m;
int main()
{
scanf("%d%d",&n,&m);
for(int i=0;i<=9;i++)
for(int j=1;j<=9;j++)
{
if((i==6||i==9)&&(j==6||j==9))
dp[2][i][j][2][0]=node(1);
else if(i==6||i==9)
dp[2][i][j][1][0]=node(1);
else if(j==6||j==9)
dp[2][i][j][1][0]=node(1);
else
dp[2][i][j][0][0]=node(1);
}
for(int i=3;i<=n;i++)
for(int l3=0;l3<=9;l3++)
for(int l2=0;l2<=9;l2++)
for(int l1=0;l1<=9;l1++)
{
int s1=l1+l2+l3,s2=l1?(l3*l3+l2*l2)%l1:0;
for(int j=0;j<=i;j++)
{
if(s1==6||s1==9||s2==6||s2==9)
{
if(l1==6||l1==9)
{
if(!j) continue;
dp[i][l1][l2][j][1]=dp[i][l1][l2][j][1]
+dp[i-1][l2][l3][j-1][1]
+dp[i-1][l2][l3][j-1][0];
}
else
{
dp[i][l1][l2][j][1]=dp[i][l1][l2][j][1]
+dp[i-1][l2][l3][j][1]
+dp[i-1][l2][l3][j][0];
}
}
else
{
if(l1==6||l1==9)
{
if(!j) continue;
dp[i][l1][l2][j][0]=dp[i][l1][l2][j][0]
+dp[i-1][l2][l3][j-1][0];
dp[i][l1][l2][j][1]=dp[i][l1][l2][j][1]
+dp[i-1][l2][l3][j-1][1];
}
else
{
dp[i][l1][l2][j][0]=dp[i][l1][l2][j][0]
+dp[i-1][l2][l3][j][0];
dp[i][l1][l2][j][1]=dp[i][l1][l2][j][1]
+dp[i-1][l2][l3][j][1];
}
} }
}
node ans=node(0);
for(int i=0;i<=9;i++)
for(int j=0;j<=9;j++)
for(int l=m;l<=n;l++)
ans=ans+dp[n][i][j][l][1];
printf("%d",ans.num[ans.num[0]]);
for(int i=ans.num[0]-1;i;i--)
{
if(ans.num[i]<1000) printf("0");
if(ans.num[i]<100) printf("0");
if(ans.num[i]<10) printf("0");
printf("%d",ans.num[i]);
}
return 0;
}

2018.9.9

洛谷 P4882 lty loves 96! 解题报告的更多相关文章

  1. 洛谷_Cx的故事_解题报告_第四题70

    1.并查集求最小生成树 Code: #include <stdio.h> #include <stdlib.h>   struct node {     long x,y,c; ...

  2. 洛谷 P2317 [HNOI2005]星际贸易 解题报告

    P2317 [HNOI2005]星际贸易 题目描述 输入输出格式 输入格式: 输出格式: 如果可以找到这样的方案,那么输出文件output.txt中包含两个整数X和Y.X表示贸易额,Y表示净利润并且两 ...

  3. 洛谷 P3802 小魔女帕琪 解题报告

    P3802 小魔女帕琪 题目背景 从前有一个聪明的小魔女帕琪,兴趣是狩猎吸血鬼. 帕琪能熟练使用七种属性(金.木.水.火.土.日.月)的魔法,除了能使用这么多种属性魔法外,她还能将两种以上属性组合,从 ...

  4. 洛谷 P2606 [ZJOI2010]排列计数 解题报告

    P2606 [ZJOI2010]排列计数 题目描述 称一个\(1,2,...,N\)的排列\(P_1,P_2...,P_n\)是\(Magic\)的,当且仅当对所以的\(2<=i<=N\) ...

  5. 洛谷1303 A*B Problem 解题报告

    洛谷1303 A*B Problem 本题地址:http://www.luogu.org/problem/show?pid=1303 题目描述 求两数的积. 输入输出格式 输入格式: 两个数 输出格式 ...

  6. 洛谷 P3084 [USACO13OPEN]照片Photo 解题报告

    [USACO13OPEN]照片Photo 题目描述 农夫约翰决定给站在一条线上的\(N(1 \le N \le 200,000)\)头奶牛制作一张全家福照片,\(N\)头奶牛编号\(1\)到\(N\) ...

  7. 洛谷 P1379 八数码难题 解题报告

    P1379 八数码难题 题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给出一种初始布局(初 ...

  8. 「洛谷P1198」 [JSOI2008]最大数 解题报告

    P1198 [JSOI2008]最大数 题目描述 现在请求你维护一个数列,要求提供以下两种操作: 1. 查询操作. 语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值. 限制: ...

  9. NOIP2015 D2T3 洛谷2680 BZOJ4326 运输计划 解题报告

    前言:个人认为这是历年NOIP中比较简单的最后一题了,因此将自己的思路与大家分享. 题目大意: 给一棵无根树,给出m条路径.允许将树上的一条边的权值改为0.求m条路径长度最大值的最小值.n,m< ...

随机推荐

  1. CRC32为例详细解析(菜鸟至老鸟进阶)

    CRC-知识解析 cyclic redundancy check 写在前面的话: 之前在做学校项目的时候用到了CRC 原理,但在网上查找的过程中,发现讲解CRC知识的资源很多,但是对新手比较友好的.讲 ...

  2. 【赛时总结】◇赛时·VII◇ Atcoder ABC-106

    [赛时·VII] ABC-106 一条比赛时莫名其妙发了半个小时呆的菜鸡&咸鱼得到了自己应有的下场……279th. Rating:1103(+) 终于AK,一次通过…… ◇ 简单总结 ABC还 ...

  3. 返回固定数据的web服务器

    import socket def handle_client(socket_con): """ 接收来自客户端的请求,并接收请求报文,解析,返回 "" ...

  4. js | javascript改变style样式和css样式

    转载 在很多情况下,都需要对网页上元素的样式进行动态的修改.在JavaScript中提供几种方式动态的修改样式,下面将介绍方法的使用.效果.以及缺陷. 1.使用obj.className来修改样式表的 ...

  5. hasOwnProperty自我理解

    暂时不考虑ES6中symbol,hasOwnProperty()方法返回的是一个对象上是否包含一个指定属性,如果含有则返回true,如果没有则返回false.   和 in 运算符不同,该方法会忽略掉 ...

  6. [Wolfgang Mauerer] 深入linux 内核架构 第一章 概述

    作为Linux开发爱好者,从事linux 开发有两年多时间.做过bsp移植,熟悉u-boot代码执行流程:看过几遍<linux 设备驱动程序开发>,分析过kernel启动流程,写过驱动,分 ...

  7. node服务端渲染(完整demo)

    简介 nodejs搭建多页面服务端渲染 技术点 koa 搭建服务 koa-router 创建页面路由 nunjucks 模板引擎组合html webpack打包多页面 node端异步请求 服务端日志打 ...

  8. Python__学习路上的坑之--引用,浅拷贝,深拷贝

    copy : 相当于只是拷贝表面一层,如果里面还有深层次的引用,那么也是直接拷贝引用的地址,而且如果拷贝对象是不可变类型比如元组,那么也是直接拷贝引用. deepcopy: 无论是拷贝可变类型还是不可 ...

  9. 数据库中where与having的区别

    从整体声明角度分析: “where”是一个约束声明,在查询数据库结果返回之前对数据库的查询条件做一个约束,即返回结果之前起作用,“where”后面不能跟聚合函数: “having”是一个过滤声明,在查 ...

  10. GCJ:2008 Round1AA-Minimum Scalar Product(有序数组倒序乘积和最小)

    题目链接:https://code.google.com/codejam/contest/32016/dashboard#s=p0 Minimum Scalar Product This contes ...