求给定精度的简单交错序列部分和 / 猜数字游戏 / 求e的近似值
2017-07-04 21:37
453 查看
练习4-3 求给定精度的简单交错序列部分和 (15分)
本题要求编写程序,计算序列部分和 1 - 1/4 + 1/7 - 1/10 + ... 直到最后一项的绝对值不大于给定精度eps。
练习4-6 猜数字游戏 (15分)
猜数字游戏是令游戏机随机产生一个100以内的正整数,用户输入一个数对其进行猜测,需要你编写程序自动对其与随机产生的被猜数进行比较,并提示大了(“Too big”),还是小了(“Too small”),相等表示猜到了。如果猜到,则结束程序。程序还要求统计猜的次数,如果1次猜出该数,提示“Bingo!”;如果3次以内猜到该数,则提示“Lucky You!”;如果超过3次但是在N(>>3)次以内(包括第N次)猜到该数,则提示“Good
Guess!”;如果超过N次都没有猜到,则提示“Game Over”,并结束程序。如果在到达N次之前,用户输入了一个负数,也输出“Game Over”,并结束程序。
练习4-7 求e的近似值 (15分)
自然常数ee可以用级数1+1/1!+1/2!+\cdots
+1/n!1+1/1!+1/2!+⋯+1/n!来近似计算。本题要求对给定的非负整数nn,求该级数的前nn项和。
1000≤1000)。
#include <stdio.h>
int factorial(int n);
int main(){
int i,n;
double e=1;
scanf("%d", &n);
for(i=1;i<=n;i++)
e+=1.0/factorial(i);
printf("%.8lf\n", e);
return 0;
}
int factorial(int n){
if(n<=1)
return 1;
return n*factorial(n-1);
}
本题要求编写程序,计算序列部分和 1 - 1/4 + 1/7 - 1/10 + ... 直到最后一项的绝对值不大于给定精度eps。
输入格式:
输入在一行中给出一个正实数eps。输出格式:
在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后六位。题目保证计算结果不超过双精度范围。输入样例1:
4E-2
输出样例1:
sum = 0.854457
输入样例2:
0.02
输出样例2:
sum = 0.826310
#include <stdio.h> #include <math.h> int main(){ int i=1,k=1; double sum=0,t,n; scanf("%lf",&n); printf("n = %.2f\n", n); do{ t=k*1.0/(3*i-2); printf("t = %.3f\n", t); sum+=t; k=-k; i++; }while(fabs(t)>n); printf("%f\n", sum); return 0; }
练习4-6 猜数字游戏 (15分)
猜数字游戏是令游戏机随机产生一个100以内的正整数,用户输入一个数对其进行猜测,需要你编写程序自动对其与随机产生的被猜数进行比较,并提示大了(“Too big”),还是小了(“Too small”),相等表示猜到了。如果猜到,则结束程序。程序还要求统计猜的次数,如果1次猜出该数,提示“Bingo!”;如果3次以内猜到该数,则提示“Lucky You!”;如果超过3次但是在N(>>3)次以内(包括第N次)猜到该数,则提示“Good
Guess!”;如果超过N次都没有猜到,则提示“Game Over”,并结束程序。如果在到达N次之前,用户输入了一个负数,也输出“Game Over”,并结束程序。
输入格式:
输入第一行中给出两个不超过100的正整数,分别是游戏机产生的随机数、以及猜测的最大次数N。最后每行给出一个用户的输入,直到出现负数为止。输出格式:
在一行中输出每次猜测相应的结果,直到输出猜对的结果或“Game Over”则结束。输入样例:
58 4 70 50 56 58 60 -2
输出样例:
Too big Too small Too small Good Guess!
#include <stdio.h> int main(){ int Maxtime,guess,in,cnt=0; printf("Input the Guess digital and maxtime:\n"); scanf("%d %d", &guess, &Maxtime); printf("Input your guess:\n"); scanf("%d", &in); while(in>0&&cnt<Maxtime){ if(in>guess){ printf("Too big\n"); cnt++; } else if(in<guess){ printf("Too small\n"); cnt++; } else{ cnt++; if(cnt<=1){ printf("Bingo!\n"); break; } else if(cnt>1 && cnt<=3){ printf("Lucky You!\n"); break; } else{ printf("Good Guess!\n"); break; } } scanf("%d", &in); } if(cnt>=Maxtime||in<0) printf("Game Over\n"); return 0; }
练习4-7 求e的近似值 (15分)
自然常数ee可以用级数1+1/1!+1/2!+\cdots
+1/n!1+1/1!+1/2!+⋯+1/n!来近似计算。本题要求对给定的非负整数nn,求该级数的前nn项和。
输入格式:
输入第一行中给出非负整数nn(\le1000≤1000)。
输出格式:
在一行中输出部分和的值,保留小数点后八位。输入样例:
10
输出样例:
2.71828180
#include <stdio.h>
int factorial(int n);
int main(){
int i,n;
double e=1;
scanf("%d", &n);
for(i=1;i<=n;i++)
e+=1.0/factorial(i);
printf("%.8lf\n", e);
return 0;
}
int factorial(int n){
if(n<=1)
return 1;
return n*factorial(n-1);
}
相关文章推荐
- 5-16 求简单交错序列前N项和 (15分)
- 递归求简单交错幂级数的部分和
- 汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。对于一个给定的字符序列S,请你把其循环左移K位后的序列输出。例如,字符序列S=”abcXYZdef”,要求输出循环左移3位后的结果,即“XYZdefabc”。是不是很简单?OK,搞定它!
- 汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。对于一个给定的字符序列S,请你把其循环左移K位后的序列输出。例如,字符序列S=”abcXYZde
- 4-16 递归求简单交错幂级数的部分和 (10分)
- 汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。对于一个给定的字符序列S,请你把其循环左移K位后的序列输出。例如,字符序列S=”abcXYZde
- 【UVA 11584】【简单dp】Partitioning by Palindromes【给定一个字符串, 问最少分为几部分可使各部分均为回文串】
- 6-5 递归求简单交错幂级数的部分和
- IBM Lotus Domino 7 中的实用 Web 服务,第 2 部分: 编写和测试简单的 Web 服务
- 构造二叉树的抽象数据类型对于给定的先序序列和中序序列,构造二叉树,并按层输出所有结点内容,要求每层结点输出一行按层输出上述二叉树所表示的森林的所有结点内容
- asp下tag的实现,简单介绍与部分代码
- javascript两个数值简单运算精度修正函数
- What's New in ArcGIS 9.3(第I部分)【简单翻译理解】
- 一个看似简单却复杂的问题:求两个字符串的 左向右匹配 所有的 最长连续的 公共子字符串( 在每个字符串中先后次序相同的) 序列
- 触发器、序列简单应用
- 使用 AIDE 实现高效率,第 4 部分: 接触点通知与简单管理器
- 一个简单的通用序列数据结构
- SWT 和 JFace,第 1 部分: 创建简单的 SWT 应用程序
- UML 工作簿, 第 2部分――序列图中的条件逻辑(转)
- 给定数据类型的补码表示,不能简单的用取反加一的方法来求反码的,介绍下2的补码系统