我写了下,发现没什么思路,有点乱,试了几小时总不对。还剩三道题了。
2条回答 默认 最新
- 冷0_O 2021-11-05 00:53关注
1、第一道题找规律,逆推注意循环次数即可。代码就不给出来了。
2、从题目来看,既然一眼就能看出羽毛球较少,则在循环计算时,羽毛球要从0开始且放置外层循环中。
代码如下:int Badminton_tennis() { //记录羽毛球(badminton_number)和乒乓球的数量(tennis_number) for(int badminton_number = 0; (80.20-(badminton_number*2.90)) > 0; badminton_number++){ for(int tennis_number = 0; ((80.20-(badminton_number*2.90 + tennis_number*1.70)) > 0); tennis_number++){ /* 相等则退出,注意:if中是两个double类型在比较是否相等,切忌写成(80.20 == (badminton_number*2.90 + tennis_number*1.70)), 正确的写法是两个double相减去和0.00001比较才行。 */ if( (80.20-(badminton_number*2.90 + tennis_number*1.70)) < 0.00001 ) return badminton_number; //返回羽毛球的数量 } } return -1; } int main() { cout << Badminton_tennis(); return 0; }
3、第三题我给出两种方法,题干中提到了需要算到19999995项以后(此时斐波那契数会很大,int已经无法保存,改用long long int)。
代码如下:long long int Fibonacci_sequence(int n) //普通求法 { if((1==n) || (2==n)) return 1; long long int a = 1,b = 1,temp = 0; n -= 2; while(n--){ temp = a + b; a = b; b = temp; } return (b%10); } long long int Fibonacci_recursion(int n) //递归 { if( n == 1 || n == 2) // 递归结束的条件 return 1; else return (Fibonacci_recursion(n-1)+Fibonacci_recursion(n-2))%10; // 如果是求其它项。 }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 2无用
悬赏问题
- ¥35 平滑拟合曲线该如何生成
- ¥100 c语言,请帮蒟蒻写一个题的范例作参考
- ¥15 名为“Product”的列已属于此 DataTable
- ¥15 安卓adb backup备份应用数据失败
- ¥15 eclipse运行项目时遇到的问题
- ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
- ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
- ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
- ¥50 成都蓉城足球俱乐部小程序抢票
- ¥15 yolov7训练自己的数据集