zoukankan
html css js c++ java
hdu1134大数+catalan数
//hdu1134大数+catalan数 #include<iostream> #include<string> #include<iomanip> #include<algorithm> using namespace std; #define MAXN 9999 #define DLEN 4 class BigNum{ private: int a[300]; int len; public: BigNum(){len = 1;memset(a,0,sizeof(a));} BigNum(const int b); BigNum(const BigNum & T); bool Bigger(const BigNum &) const; BigNum & operator=(const BigNum &); BigNum & Add(const BigNum &); BigNum & Sub(const BigNum &); BigNum operator+(const BigNum &) const; BigNum operator-(const BigNum &) const; BigNum operator*(const BigNum &) const; BigNum operator/(const int &) const; void Print(); }; BigNum::BigNum(const int b) { int c,d = b; len = 0; memset(a,0,sizeof(a)); while(d > MAXN){ c = d - d / (MAXN + 1) * (MAXN + 1); cout<<d / (MAXN + 1) * (MAXN + 1)<<endl; cout<<c<<endl; d = d / (MAXN + 1); a[len++] = c; } a[len++] = d; } BigNum::BigNum(const BigNum & T) : len(T.len) { int i; memset(a,0,sizeof(a)); for(i = 0 ; i < len ; i++) a[i] = T.a[i]; } bool BigNum::Bigger(const BigNum & T) const { int ln; if(len > T.len) return true; else if(len == T.len){ ln = len - 1; while(a[ln] == T.a[ln] && ln >= 0) ln--; if(ln >= 0 && a[ln] > T.a[ln]) return true; else return false; } else return false; } BigNum & BigNum::operator=(const BigNum & n) { len = n.len; memset(a,0,sizeof(a)); for(int i = 0 ; i < len ; i++) a[i] = n.a[i]; return *this; } BigNum & BigNum::Add(const BigNum & T) { int i,big; big = T.len > len ? T.len : len; for(i = 0 ; i < big ; i++) { a[i] = a[i] + T.a[i]; if(a[i] > MAXN) { a[i + 1]++; a[i] = a[i] - MAXN - 1; } } if(a[big] != 0) len = big + 1; else len = big; return *this; } BigNum & BigNum::Sub(const BigNum & T) { int i,j,big; big = T.len > len ? T.len : len; for(i = 0 ; i < big ; i++){ if(a[i] < T.a[i]){ j = i + 1; while(a[j] == 0) j++; a[j--]--; while(j > i) a[j--] += MAXN; a[i] = a[i] + MAXN + 1 - T.a[i]; } else a[i] -= T.a[i]; } len = big; while(a[len - 1] == 0 && len > 1) len--; return *this; } BigNum BigNum::operator*(const BigNum & T) const { BigNum ret; int i,j,up; int temp,temp1; for(i = 0 ; i < len ; i++){ up = 0; for(j = 0 ; j < T.len ; j++){ temp = a[i] * T.a[j] + ret.a[i + j] + up; if(temp > MAXN){ temp1 = temp - temp / (MAXN + 1) * (MAXN + 1); up = temp / (MAXN + 1); ret.a[i + j] = temp1; } else { up = 0; ret.a[i + j] = temp; } } if(up != 0) ret.a[i + j] = up; } ret.len = i + j; while(ret.a[ret.len - 1] == 0 && ret.len > 1) ret.len--; return ret; } BigNum BigNum::operator/(const int & b) const { BigNum ret; int i,down = 0; for(i = len - 1 ; i >= 0 ; i--){ ret.a[i] = (a[i] + down * (MAXN + 1)) / b; down = a[i] + down * (MAXN + 1) - ret.a[i] * b; } ret.len = len; while(ret.a[ret.len - 1] == 0) ret.len--; return ret; } void BigNum::Print() { int i; cout << a[len - 1]; for(i = len - 2 ; i >= 0 ; i--){ cout.width(DLEN); cout.fill('0'); cout << a[i]; } cout << endl; } int main() { BigNum x[110]; long n,i; x[1]=1; x[2]=2; x[3]=5; for(i=3;i<100;i++) { x[i+1]=x[i]*(4*i+2)/(i+2); } while(cin>>n&&n!=-1) { x[n].Print(); } return 0; }
查看全文
相关阅读:
ES 内存深度解析
Spring Cache介绍和使用
mysql 索引及索引创建原则
mysql中四种存储引擎的区别和选择
Java中数组、List、Set互相转换
COGS 1151 活动安排
洛谷P1650赛马与codevs 2181 田忌赛马
5月3日济南清北学堂随堂测试题目
codevs 1206 保留两位小数
codevs 1203 判断浮点数是否相等
原文地址:https://www.cnblogs.com/windmissing/p/2559898.html
最新文章
提高程序员工作效率的5个诀窍
Yaf零基础学习总结4-Yaf的配置文件
Cookie与Session的区别-总结很好的文章
PHP自带Session隐患(session文件独占锁引起阻塞)
《Memcache学习总结》[PDF]发布
SpringCloud(六)之 网关概念、Zuul项目搭建-(利用Zuul 实现鉴权和限流实战)
SpringCloud(五)之Spring Cloud 中 Feign结合Hystrix断路器开发实战
SpringCloud(四)之Netflix开源组件断路器Hystrix介绍
SpringCloud(三)之Feign实现负载均衡的使用
SpringCloud(二)之Ribbon的实现负载均衡的基本应用
热门文章
SpringCloud(一)之微服务核心组件Eureka(注册中心)的介绍和使用
微服务中的CAP定律
nginx详解(代理服务器的解释+nginx 在linux 下的安装+nginx.conf 中的配置解释)
springboot 整合logback(有全套的日志配置文件)
@Transactional(事务讲解)和springboot 整合事务
史上最全面的Spring-Boot-Cache使用与整合
spring boot2集成ES详解
SpringBoot整合mybatis、shiro、redis实现基于数据库的细粒度动态权限管理系统实例
SQL编程:group by合并结果字符串 ---> group_concat函数就能行
mysql 统计一个字符在字符串中出现的次数
Copyright © 2011-2022 走看看