打表

        写这篇文章是告诉大家我的一个打表方法,开始的时候自己觉得打一个1000的表比较困难,但是真的自己去尝试的话不要几分钟~~什么都得自己去尝试,当然下面这道题肯定有比打表更加适合的方法。

       zjut 1218(n!中的0)题目链接:http://acm.zjut.edu.cn/ShowProblem.aspx?ShowID=1218

      与以前求阶乘中的0的个数不同的是以前求n!中的0是只需求尾数的0即可,希望各位看清楚题目。不会做,没有找到规律,但是知道求高精度的阶乘值,但是超时,没办法,想到了打表,开始时候觉的好复杂,但实际操作时觉得不是那么复杂,主要是介绍下我的打表过程:

      题目要求是1000个数字,我先写了一个生成1-1000的算法,for循环,并记录在新建记事本中,并复制到高精度模板中,生成每个对应的值,按全选后复制运行结果,然后写个打表程序,具体代码为:

后将前面复制的数据放到高精度阶乘的模板(怎样在DEV中复制粘贴----对于有很多组测试数据时,我们最好的方法是借助记事本,先将要测试的数据写入到记事本,然后调试的时候右键单击调试框上的黑色部分,在下拉列表中选中粘贴,要提取数据的话可以全选后复制即可)中调试,就会直接出现我们所需的数据排列,后复制到我们的打表程序中即可,所以打一个从1-1000的表并不要几分钟。
高精度阶乘模板:

 

下面是这道题的打表程序:

 

 POJ 1008解题报告,只是做下笔记。翻译~~~

/***************************************************************************************************************
Description
上周末,M.A. Ya教授对古老的玛雅有了一个重大发现。从一个古老的节绳(玛雅人用于记事的工具)中,教授发现玛雅人使用了
一个一年有365天的叫做Haab的历法。这个Haab历法拥有19个月,在开始的18个月,一个月有20天,月份的名字分别是pop, no, 
zip, zotz, tzec, xul, yoxkin, mol, chen, yax, zac, ceh, mac, kankin, muan, pax, koyab, cumhu。这些月份中的日期用
0到19表示。Haab历的最后一个月叫做uayet,它只有5天,用0到4表示。玛雅人认为这个日期最少的月份是不吉利的,在这个月法
庭不开庭,人们不从事交易,甚至没有人打扫屋中的地板。因为宗教的原因,玛雅人还使用了另一个历法,在这个历法中年被称为
Tzolkin(holly年),一年被分成13个不同的时期,每个时期有20天,每一天用一个数字和一个单词相组合的形式来表示。使用的数
字是1~13,使用的单词共有20个,它们分别是:imix, ik, akbal, kan, chicchan, cimi, manik, lamat, muluk, ok, chuen, 
eb, ben, ix, mem, cib, caban, eznab, canac, ahau。注意:年中的每一天都有着明确唯一的描述,比如,在一年的开始,日期
如下描述:1 imix,2 ik,3 akbal,4 kan,5 chicchan,6 cimi,7 manik,8 lamat,9 muluk,10 ok,11 chuen,12 eb,13 ben,1 ix,
2 mem,3 cib,4 caban,5 eznab,6 canac,7 ahau,8 imix,9 ik,10 akbal ……也就是说数字和单词各自独立循环使用。
Haab历和Tzolkin历中的年都用数字0, 1, ……表示,数字0表示世界的开始。所以第一天被表示成:
Haab: 0. pop 0
Tzolkin: 1 imix 0
请帮助M.A. Ya教授写一个程序可以把Haab历转化成Tzolkin历。
Input
Haab历中的数据由如下的方式表示:日期. 月份 年数
输入中的第一行表示要转化的Haab历日期的数据量。下面的每一行表示一个日期,年数小于5000。
Output
Tzolkin历中的数据由如下的方式表示:
天数字 天名称 年数
第一行表示输出的日期数量。下面的每一行表示一个输入数据中对应的Tzolkin历中的日期。
****************************************************************************************************************/
#include<iostream>
#include<string>
#include<cstring>
#include<cstdio>
using namespace std;
string month,Haab[20]={"pop","no","zip","zotz","tzec","xul","yoxkin","mol","chen","yax",
                 "zac","ceh","mac","kankin","muan","pax","koyab","cumhu","uayet"},
       Tzokin[20]={"imix","ik","akbal","kan","chicchan","cimi","manik","lamat","muluk",
                   "ok","chuen","eb","ben","ix","mem","cib","caban","eznab","canac","ahau"};     
int m,num,sum,day,year;                        
int main()
{   cin>>num;
    cout<<num<<endl;
    while(num--)
    {   scanf("%d.",&day);
        cin>>month>>year;
        for(m=0;m<19;m++)
            if(month.compare(Haab[m])==0) break;
        sum=year*365+m*20+day;
        year=sum/260;day=(sum-20*(sum-year*260)%20)%13+1;
        cout<<day<<" "<<Tzokin[(sum-year*260)%20]<<" "<<year<<endl;
    }
    return 0;
}


 

 

 

 

 

 

 

 

 

 

 

 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值