【高精度练习+卡特兰数】【Uva1133】Buy the Ticket
Buy the Ticket
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 4726 Accepted Submission(s): 1993
Suppose the cinema only has one ticket-office and the price for per-ticket is 50 dollars. The queue for buying the tickets is consisted of m + n persons (m persons each only has the 50-dollar bill and n persons each only has the 100-dollar bill).
Now the problem for you is to calculate the number of different ways of the queue that the buying process won't be stopped from the first person till the last person.
Note: initially the ticket-office has no money.
The buying process will be stopped on the occasion that the ticket-office has no 50-dollar bill but the first person of the queue only has the 100-dollar bill.
3 0
3 1
3 3
0 0
Test #1:
6
Test #2:
18
Test #3:
180
#include <cstdio>
#include <cstdlib>
#include <cmath>
#include <cstring>
#include <ctime>
#include <algorithm>
#include <iostream>
#include <sstream>
#include <string>
#define oo 0x13131313
using namespace std;
int C[102][102][50];
int len[102][102];
int JC[102][200];
int LEN[102];
void getadd(int a,int b)
{
int a1=a,a2=a-1,b1=b-1,b2=b;
int temp=0;
len[a][b]=max(len[a1][b1],len[a2][b2])+1;
for(int i=0;i<len[a][b];i++)
{
temp+=C[a1][b1][i]+C[a2][b2][i];
C[a][b][i]=temp%10;
temp=temp/10;
}
if(C[a][b][len[a][b]-1]==0) len[a][b]--;
}
void getC()
{
C[1][1][0]=1;
len[1][1]=1;
for(int i=1;i<=100;i++)
{
C[i][0][0]=1;
len[i][0]=1;
}
for(int j=1;j<=100;j++)
for(int i=1;i<=100;i++)
{
len[i][j]=1;
if(j<=i)
getadd(i,j);
}
}
void getx(int X)
{
double k=(log((double)X)/log(10.0));
int K=(int)(k+1);
LEN[X]=LEN[X-1]+K;
int temp=0;
for(int i=0;i<LEN[X];i++)
{
temp+=JC[X-1][i]*X;
JC[X][i]=temp%10;
temp=temp/10;
}
if(JC[X][LEN[X]-1]==0) LEN[X]--;
}
void getJC()
{
JC[0][0]=1;LEN[0]=1;JC[1][0]=1;LEN[1]=1;
for(int i=1;i<=100;i++)
getx(i);
}
void highXhigh(int *c,int &lenc,int *a,int lena,int *b,int lenb)
{
lenc=lena+lenb;
int temp=0;
for(int i=0;i<lena;i++)
for(int j=0,temp=0;j<=lenb;j++)
{
temp+=a[i]*b[j]+c[i+j];
c[i+j]=temp%10;
temp=temp/10;
}
if(c[lenc-1]==0) lenc--;
}
int buffer1[500],buffer2[500],len1,len2;
void getans(int n,int m)
{
memset(buffer1,0,sizeof(buffer1));
memset(buffer2,0,sizeof(buffer2));
highXhigh(buffer1,len1,JC[n],LEN[n],C[n][m],len[n][m]);
highXhigh(buffer2,len2,buffer1,len1,JC[m],LEN[m]);
for(int i=len2-1;i>=0;i--)
{
printf("%d",buffer2[i]);
}
}
int main()
{
// freopen("a.in","r",stdin);
// freopen("a.out","w",stdout);
getC();
getJC();
int Case=0,n,m;
while(scanf("%d%d",&n,&m)!=EOF &&(n!=0||m!=0))
{
Case++;
printf("Test #%d:\n",Case);
if(n>=m)
getans(n,m);
else printf("0");
printf("\n");
}
return 0;
}
有几点要注意的
#include <cstdio>
#include <cstdlib>
#include <cmath>
#include <cstring>
#include <ctime>
#include <algorithm>
#include <iostream>
#include <sstream>
#include <string>
#define oo 0x13131313
#define B 10000
using namespace std;
int C[102][102][30];
int len[102][102];
int JC[102][50];
int LEN[102];
void getadd(int a,int b)
{
int a1=a,a2=a-1,b1=b-1,b2=b;
int temp=0;
len[a][b]=max(len[a1][b1],len[a2][b2])+1;
for(int i=0;i<len[a][b];i++)
{
temp+=C[a1][b1][i]+C[a2][b2][i];
C[a][b][i]=temp%B;
temp=temp/B;
}
if(C[a][b][len[a][b]-1]==0) len[a][b]--;
}
void getC()
{
C[1][1][0]=1;
len[1][1]=1;
for(int i=1;i<=100;i++)
{
C[i][0][0]=1;
len[i][0]=1;
}
for(int j=1;j<=100;j++)
for(int i=1;i<=100;i++)
{
len[i][j]=1;
if(j<=i)
getadd(i,j);
}
}
void getx(int X)
{
// double k=(log((double)X)/log(10.0));
// int K=(int)(k+1);
LEN[X]=LEN[X-1]+1;
int temp=0;
for(int i=0;i<LEN[X];i++)
{
temp+=JC[X-1][i]*X;
JC[X][i]=temp%B;
temp=temp/B;
}
if(JC[X][LEN[X]-1]==0) LEN[X]--;
}
void getJC()
{
JC[0][0]=1;LEN[0]=1;JC[1][0]=1;LEN[1]=1;
for(int i=1;i<=100;i++)
getx(i);
}
void highXhigh(int *c,int &lenc,int *a,int lena,int *b,int lenb)
{
lenc=lena+lenb;
int temp=0;
for(int i=0;i<lena;i++)
for(int j=0,temp=0;j<=lenb;j++)
{
temp+=a[i]*b[j]+c[i+j];
c[i+j]=temp%B;
temp=temp/B;
}
if(c[lenc-1]==0) lenc--;
}
int buffer1[120],buffer2[120],len1,len2;
void getans(int n,int m)
{
memset(buffer1,0,sizeof(buffer1));
memset(buffer2,0,sizeof(buffer2));
highXhigh(buffer1,len1,JC[n],LEN[n],C[n][m],len[n][m]);
highXhigh(buffer2,len2,buffer1,len1,JC[m],LEN[m]);
if(len2-1>=0) printf("%d",buffer2[len2-1]);
for(int i=len2-2;i>=0;i--)
{
printf("%04d",buffer2[i]);
}
}
int main()
{
freopen("a.in","r",stdin);
freopen("b.out","w",stdout);
getC();
getJC();
int Case=0,n,m;
while(scanf("%d%d",&n,&m)!=EOF &&(n!=0||m!=0))
{
Case++;
printf("Test #%d:\n",Case);
if(n>=m)
getans(n,m);
else printf("0");
printf("\n");
}
return 0;
}
改压位十分简单
【高精度练习+卡特兰数】【Uva1133】Buy the Ticket的更多相关文章
- Contset Hunter 1102 高精度求卡特兰数
用递推的方式写的写挂了,而如果用组合数又不会高精度除法,偶然看到了别人的只用高精度乘低精度求组合数的方法,记录一下 #include<bits/stdc++.h> using namesp ...
- HDU 1023 Traning Problem (2) 高精度卡特兰数
Train Problem II Time Limit: 1000MS Memory Limit: 32768KB 64bit IO Format: %I64d & %I64u Sub ...
- Buy the Ticket(卡特兰数+递推高精度)
Buy the Ticket Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Tota ...
- 【HDU 1133】 Buy the Ticket (卡特兰数)
Buy the Ticket Problem Description The "Harry Potter and the Goblet of Fire" will be on sh ...
- HDUOJ---1133(卡特兰数扩展)Buy the Ticket
Buy the Ticket Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)To ...
- HDU1133 Buy the Ticket —— 卡特兰数
题目链接:https://vjudge.net/problem/HDU-1133 Buy the Ticket Time Limit: 2000/1000 MS (Java/Others) Me ...
- HDOJ/HDU 1133 Buy the Ticket(数论~卡特兰数~大数~)
Problem Description The "Harry Potter and the Goblet of Fire" will be on show in the next ...
- Buy the Ticket HDU 1133 卡特兰数应用+Java大数
Problem Description The "Harry Potter and the Goblet of Fire" will be on show in the next ...
- 【hdoj_1133】Buy the Ticket(卡特兰数+大数)
题目:http://acm.hdu.edu.cn/showproblem.php?pid=1133 题目的意思是,m个人只有50元钱,n个人只有100元整钱,票价50元/人.现在售票厅没钱,只有50元 ...
随机推荐
- node 安装express
环境:win7 64位旗舰版 1 安装nodejs 2 安装npm 3 安装express 重点介绍安装express,前提是你已经安装nodejs和npm了. 1 安装express npm ins ...
- DataGridView常用功能
最近做Winform开发,DataGridView是必不可少的控件.整理了一下用到的基本功能的设置 1.情景1:当GridView的列没有自动填充,会出现一片空白的地方,特别不美观. 设置 自动填充G ...
- Python3.5入门学习记录-列表、元组、字典
1.列表 python列表的定义使用[] list = [1,2,3,4,5] #创建一个心列表list 获取列表中的值 first = list[0] #list中第一个值 last = list[ ...
- SQL Server 数据类型 Decimal介绍
为SQL Server 数据类型,属于浮点数类型.存储数据范围是: -1038~1038-1 的固定精度和小数位的数字.一个decimal类型的数据占用了2~17个字节.decimal数据类型在SQL ...
- linux命令--virtualenv
virtualenv可以搭建虚拟且独立的python环境,可以使每个项目环境与其他项目独立开来,保持环境的干净,解决包冲突问题. 一.安装virtualenv virtualenv实际上是一个pyth ...
- shell中的环境变量
局部(local)环境变量 定义局部环境变量的方式如下: variableName=value 需要注意的是variableName前面没有$符号,并且=两边没有空格. 局部环境变量只能在当前shel ...
- 【solr基础教程之九】客户端
一.Java Script 1.由于Solr本身可以返回Json格式的结果,而JavaScript对于处理Json数据具有天然的优势,因此使用JavaScript实现Solr客户端是一个很好的选择. ...
- sql中插入多条记录-微软批处理
这是使用批处理的一个例子: System.IO.StreamWriter messagelog = null; string messageString = ""; SqlConn ...
- OpenCV图片类cv::Mat和QImage之间进行转换(好多相关文章)
在使用Qt和OpenCV混合编程时,我们有时需要在两种图片类cv::Mat和QImage之间进行转换,下面的代码参考了网上这个帖子: //##### cv::Mat ---> QImage ## ...
- JavaSctipr 兼容、技巧、牛角尖
关于JavaSctipt的兼容性,最懒的办法就是用jQuery的工具函数.尽量不要用那些什么ECMAScript之类的函数,因为很多浏览器都会报找不到函数的错误.下面列出一些在开发过程中碰到过的jav ...