HDU 3709 Balanced Number(数位dp)

原创 2016年08月31日 00:52:26

题目链接:
HDU 3709 Balanced Number
题意:
把一个数字都某一位看成一个支点,左右的权值和是各个位上的数字到支点的距离乘积之和。如果存在某个支点使得左右权值和相等,这个数字就称为Balanced Number。给定区间[L,R],求Balanced Number的数字个数。
数据范围:0LR1018
分析:
BZOJ 1799 self同类分布类似,我们枚举支点位置即可。因为对于一个Balanced Number它的支点只会有1个。仔细想一下就好了。
需要注意的是记忆化的时候我们记录sum是左边权值和减去右边权值和,这样子既有利于剪枝也不会出错。还有一点对于一个区间上界数字有len位的区间,我们把0计算了len次,所以最后还要减掉len1

#include <stdio.h>
#include <string.h>
#include <algorithm>
#include <math.h>
using namespace std;
typedef long long ll;

int digit[20];
ll dp[20][20][4000];

ll dfs(int pos, int pivot, int sum, int limit)
{
    if (sum < 0 || sum > pivot * (pivot + 1) / 2 * 9) return 0;
    if (pos == -1) return sum == 0;
    if (!limit && dp[pos][pivot][sum] != -1) return dp[pos][pivot][sum];
    int last = limit ? digit[pos] : 9;
    ll ret = 0;
    for (int i = 0; i <= last; ++i) {
        int next_sum = sum + i * (pos - pivot);
        ret += dfs(pos - 1, pivot, next_sum, limit && i == last);
    }
    if (!limit) dp[pos][pivot][sum] = ret;
    return ret;
}

ll solve(ll x)
{
    if (x < 0) return 0;
    else if (x == 0) return 1;
    memset(digit, 0, sizeof(digit));
    int len = 0;
    while (x) {
        digit[len++] = x % 10;
        x /= 10;
    }
    ll ret = 0;
    for (int i = 0; i < len; ++i) {
        ret += dfs(len - 1, i, 0, 1);
    }
    return ret - (len - 1); // 把0算了len次
}

int main()
{
    int T;
    ll L, R;
    scanf("%d", &T);
    while (T--) {
        memset(dp, -1, sizeof(dp));
        scanf("%lld%lld", &L, &R);
        printf("%lld\n", solve(R) - solve(L - 1));
    }
    return 0;
}
版权声明:缥缈玉京人,想语然、京兆眉妩。

相关文章推荐

HDU 3709 Balanced Number (数位DP)

Balanced Number Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others...

hdu 3709 Balanced Number(数位dp)

http://acm.hdu.edu.cn/showproblem.php?pid=3709 平衡数。枚举支点的位置,同时记录力臂。 dp[i][j][k]表示当前处理到第i个数,支点的位...

HDU 3709 Balanced Number(数位dp)

题意:若某数,固定某位为支点,得到平衡的则称为平衡数。给定区间问有多少个。 思路:数位dp。 #include #include #include #include #include #...

HDU3709 Balanced Number[数位DP]

C - Balanced Number  HDU - 3709  题意: 给T组数据,每组数据给出一个x和y,求出[x,y]当中满足以其中一位为平衡点,满足在平衡点的左右两边...

数位DP-HDU-3709-Balanced Number

Balanced NumberTime Limit: 10000/5000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Others) ...

HDU 3709 Balanced Number(数位dp)

人生第一道数位dp,还几乎是自己想出来的,纪念一下……         数字要平衡,即力矩平衡。一般来说,数位dp求一个区间内满足条件的方案数,都是要用区间的性质,即对于询问区间[l,r]我们的最后过...

HDU-3709 Balanced Number (数位DP)

又是一个状态很难想的数位DP 对于一个非0数x,最多只存在一个支点pivot使力矩为0 所以支点不同时的统计个数不重复(不包括0),可以直接相加 所以可以设dp[i][j][k]表示长度为i时,支点为...

【1】【数位DP】HDU3709 Balanced Number

2016/7/27 暑期集训

hdu 3709Balanced Number(数位dp)

Balanced Number Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others...

HDU 3709 Balanced Number (数位dp)

题意: Balanced Number:存在一个pivot在某位,使得分成的左右两部分∑{d[i]∗|i−p|}相等Balanced\ Number: 存在一个pivot在某位, 使得分成的左右两...
  • lwt36
  • lwt36
  • 2015-10-21 17:37
  • 155
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)