组合数算法.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
组合数算法

经典与趣味算法 一 经典算法 数值计算 日历相关算法 组合数算法 埃拉托色尼筛选法求素数 插入排序 二 过程模拟类算法 小球称重 魔方阵 循环报数 发牌算法 农夫过河 走迷宫 1 数值算法 数值算法:计算机用来实现像计算平方根这样的数学函数的技术 1 )连续逼近: 例1:求平方根 Double Sqrt1(double x) {double g; if(x==0) return(0); if(x0) {cout“error input”;exit(1);} g=x; while(fabs(x-g*g)1e-5) g=(g+x/g)/2); return(g); } 2 级数展开法: 总结 大多数问题可以用不同的算法来解决 在不同的算法中进行选择时程序员的重要任务,要考虑算法的效率、可维护性、清晰性 在改善程序的其他方面时,不能牺牲程序的正确性 程序中的出错情况要向用户报告 2日历相关算法 计算明天的日期 计算日期是该年的第几天 计算星期 打印日历 将一年中每月的天数记录在2维数组中,令计算简单 int leap[][12]={{31,28,31,30,31,30,31,31,30,31,30,31},{31,29,31,30,31,30,31,31,30,31,30,31}}; 计算第二天日期: 计算星期几 int firstDayOfMonth(int day int month,int year) { int weekday,i; weekday=Monday;//Monday=1 for(i=1900;iyear;i++) { weekday=(weekday+365)%7; if (isLeapYear(i)) weekday=(weekday+1)%7; } for(i=1;imonth;i++) weekday=(weekday+monthDays(i,year))%7; Weekday=(weekday+day)%7; return weekday; } 打印日历 步骤: 输入年份 逐月打印日历 打印月头(月份名称) 计算该月有多少天 计算该月1日是星期几 首行留空; 从1号开始,打印每天,到星期六换行 #include iostream.h #include iomanip.h #include stdio.h //weekday 0-6 //month 1-12 #define Sunday 0 #define Monday 1 #define Tuesday 2 #define Wednesday 3 #define Thursday 4 #define Friday 5 #define Saturday 6 int getYearFromUser(void); void printCalendar(int year); void printCalendarMonth(int month,int year); void IndentFirstLine(int weekday); int monthDays(int month,int year); int firstDayOfMonth(int month,int year); char *monthName(int month); bool isLeapYear(int year); /*主函数*/ void main() {int year; year=getYearFromUser(); printCalendar(year); } /* 获得用户输入的日期*/ int getYearFromUser(void) { int year; while(1) { coutplease input a yearendl; cinyear; if(year=1900) return year; coutthe year must be at least 1900endl; } } /*打印日历*/ void printCalendar(int year) {int month; for(month=1;month=12;month++) { printCalendarMonth(month, year); coutendl; } } /*打印一个月的日历*/ void printCalendarMonth(int month,int year) {int weekday,ndays,day; coutmonthName(month) yearendl; coutSUN MON TUE WED THU FRI SATendl; ndays=monthDa

文档评论(0)

me54545 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档