码迷,mamicode.com
首页 > 其他好文 > 详细

HDU1502 Regular Words DP+大数

时间:2017-10-15 19:42:23      阅读:135      评论:0      收藏:0      [点我收藏+]

标签:str   long   oid   mem   class   int()   for   turn   mes   

要是c语言可以和java一样写大数就好了,或者我会写重载就好了,最后还是只能暴力一把。

开始写的记忆化搜索,然而n=10就超过LL了

#include<cstdio>
#include<cstdlib>
#include<iostream>
#include<memory.h>
#include<algorithm>
#include<algorithm>
#include<cstring>
#include<string>
using namespace std;
#define LL long long
int a[61][61][61][110],n;
void _add(int x,int y,int z,int u,int v,int w)
{
    for(int i=1;i<=100;i++){
      a[x][y][z][i]+=a[u][v][w][i];
      a[x][y][z][i+1]+=a[x][y][z][i]/10;
      a[x][y][z][i]%=10;
    }
}
void _print()
{
    int i,j,k;
    for(i=100;i>1;i--) if(a[n][n][n][i]!=0) break;
    for(;i>=1;i--) printf("%d",a[n][n][n][i]);
    printf("\n\n");
}
int main()
{
    int i,j,k;
    a[0][0][0][1]=1;
    for(i=1;i<=60;i++)
     for(j=0;j<=i;j++)
      for(k=0;k<=j;k++)
      {
         if(k>0) _add(i,j,k,i,j,k-1);
         if(i>j) _add(i,j,k,i-1,j,k);
         if(j>k) _add(i,j,k,i,j-1,k);
         
      }
    while(~scanf("%d",&n)){
         _print();
    }
    return 0;
}

 

HDU1502 Regular Words DP+大数

标签:str   long   oid   mem   class   int()   for   turn   mes   

原文地址:http://www.cnblogs.com/hua-dong/p/7672787.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!