打表

来源:互联网 发布:发育宝狗粮怎么样 知乎 编辑:程序博客网 时间:2024/04/27 14:45

        写这篇文章是告诉大家我的一个打表方法,开始的时候自己觉得打一个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 0Tzolkin: 1 imix 0请帮助M.A. Ya教授写一个程序可以把Haab历转化成Tzolkin历。InputHaab历中的数据由如下的方式表示:日期. 月份 年数输入中的第一行表示要转化的Haab历日期的数据量。下面的每一行表示一个日期,年数小于5000。OutputTzolkin历中的数据由如下的方式表示:天数字 天名称 年数第一行表示输出的日期数量。下面的每一行表示一个输入数据中对应的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;}


 

 

 

 

 

 

 

 

 

 

 

 

原创粉丝点击