77范文网 - 专业文章范例文档资料分享平台

算法与程序实践1(简单计算)

来源:网络收集 时间:2019-03-22 下载这篇文档 手机版
说明:文章内容仅供预览,部分内容可能不全,需要完整文档或者需要复制内容,请下载word后使用。下载word有问题请添加微信号:或QQ: 处理(尽可能给您提供完整文档),感谢您的支持与谅解。点击这里给我发消息

目 录

CS1:斐波那契数列 ......................................................................................................................... 1 CS2:正整数解 ................................................................................................................................. 3 CS3:鸡兔同笼 ................................................................................................................................. 4 CS4:棋盘上的距离 ......................................................................................................................... 5 CS5:校门外的树木 ......................................................................................................................... 7 CS6:填词......................................................................................................................................... 8 CS7:装箱问题 ................................................................................................................................. 9 CS8:求平均年龄 ........................................................................................................................... 10 CS9:数字求和 ............................................................................................................................... 11 CS10:两倍..................................................................................................................................... 11 CS11:肿瘤面积 ............................................................................................................................. 12 CS12:肿瘤检测 ............................................................................................................................. 12 CS13:垂直直方图 ......................................................................................................................... 13 CS14:谁拿了最多的奖学金 ......................................................................................................... 14 CS15:简单密码 ............................................................................................................................. 15 CS16:化验诊断 ............................................................................................................................. 16 CS17:密码..................................................................................................................................... 17 CS18:数字阶梯 ............................................................................................................................. 18 CS19:假票..................................................................................................................................... 18 CS20:纸牌(Deck) ..................................................................................................................... 19

《算法与程序实践》习 题 解 答1——简单计算

这一章的主要目的是通过编写一些简单的计算题,熟悉C/C++语言的基本语法。 基本思想:解决简单的计算问题的基本过程包括将一个用自然语言描述的实际问题抽象成一个计算问题,给出计算过程,继而编程实现计算过程,并将计算结果还原成对原来问题的解答。这里首要的是读懂问题,搞清输入和输出的数据的含义及给出的格式,并且通过输入输出样例验证自己的理解是否正确。

课堂练习:CS1、CS2、CS3 课堂讲解:CS4(CS5)

A类(满分80)课堂练习:CS8、CS9、CS10 B类(满分100)课堂上机:CS11、CS20

CS1:斐波那契数列

问题描述:

已知斐波那契数列第n项的计算公式如下。在计算时有两种算法:递归和非递归,请分别给出这两种算法。

当n=0时,Fib(n)=0,当n=1时,Fib(n)=1,当n>1时,Fib(n)= Fib(n-1)+ Fib(n-2)

输入:

第一行是测试数据的组数m,后面跟着m行输入。每行包括一个项数n和一个正整数a。(m,n,a均大于0,且均小于10000000)

输出:

输出包含m行,每行对应一个输入,若a不大于Fib(n),则输出Yes,否则输出No

输入样例: 3 3 3 10 50 24 20000

输出样例: No Yes Yes

参考程序1(zzg): 循环版

#include int main() { int fn2,fn1,fn,m,n,a,i,j;

1

fn2=0; fn1=1; //freopen(\ //freopen(\ scanf(\ for(i=1;i<=m;i++) { scanf(\ if(n==1) { if(a<=fn1) printf(\ else printf(\ } else { for(j=2;j<=n;j++) { fn=fn2+fn1; fn2=fn1; fn1=fn; if(a<=fn) { printf(\ break; } } if(j>n) printf(\ } } return 1; }

递归版(zzg) #include int fib(int n) { if(n<2) return n==0?0:1; else

2

return fib(n-2)+fib(n-1); }

int main() { int m,n,a,i,j; scanf(\ for(i=1;i<=m;i++) { scanf(\ for(j=1;j<=n;j++) { if(a<=fib(j)) { printf(\ break; } } if(j>n) printf(\ } return 1; }

注意事项:

这题主要考察递归与非递归的用法,还有数值越界的情况。 1)测试数据可取一下 1 1和1 3试一下。 2)测试数据可以取一下 50 1000和1000 1000。程序中若考虑到值的越界就没问题或者考虑使用break也可以。

CS2:正整数解

求x2+y2=2000的正整数解,输出所有不同的解。

参考程序:

#include #include

int main() { int x,y,m; m=(int)sqrt(2000); for(x=1;x<=m;x++)

3

for(y=x;y<=m;y++) if(x*x+y*y==2000) printf(\ return 0; }

注意事项:

这题主要考察枚举的用法,还有求平方根(数学函数)的用法。

1) 要考虑x和y可调换,所以需要加上y>=x,这样就能保证不会出现重复的解

2) 考虑一下优化的问题for(y=x;y<=m;y++)可以优化为:for(y=m;y>=x;y--),甚至还可以 int temp=(int)sqrt(2000-x*x) for(y=temp;y>=x;y--)

CS3:鸡兔同笼

(来源:poj.grids.cn 2750) 问题描述:

一个笼子里面关了鸡和兔子(鸡有2只脚,兔子有4只脚,没有例外)。已经知道了笼子里面脚的总数a,问笼子里面至少有多少只动物,至多有多少只动物。 输入:

第1 行是测试数据的组数n,后面跟着n行输入。每组测试数据占1行,包括一个正整数a (a < 32768) 。

输出:

n 行,每行输出对应一个输入。输出是两个正整数,第一个是最少的动物数,第二个是最多的动物数,两个正整数用空格分开。如果没有满足要求的情况出现,则输出2个0。 输入样例:

2 3 20 输出样例:

0 0 5 10

参考程序:

#include

int main() {

int nCase,nFeet,i; scanf(\ for(i=1;i<=nCase;i++)

4

百度搜索“77cn”或“免费范文网”即可找到本站免费阅读全部范文。收藏本站方便下次阅读,免费范文网,提供经典小说综合文库算法与程序实践1(简单计算)在线全文阅读。

算法与程序实践1(简单计算).doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印 下载失败或者文档不完整,请联系客服人员解决!
本文链接:https://www.77cn.com.cn/wenku/zonghe/536165.html(转载请注明文章来源)
Copyright © 2008-2022 免费范文网 版权所有
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ: 邮箱:tiandhx2@hotmail.com
苏ICP备16052595号-18
× 注册会员免费下载(下载后可以自由复制和排版)
注册会员下载
全站内容免费自由复制
注册会员下载
全站内容免费自由复制
注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: