#pta循环作业

7-7 计算阶乘和

1.题目
 
 

2.设计思路     此题目比一道类似的经典题目的区别就是不是直接的数字累加而是每次的数字先累乘之后再累加

只需要在累加之前处理一下所要加的数字就可以实现了

3.流程图

#include<stdio.h>
int main(){
    int N,i,t=1,S=0;
    scanf("%d",&N);
    for(i=1;i<=N;i++){
        t=t*i;
        S+=t;
        }
        printf("%d",S);
    }

4.答案结果

题目二:7-5

 

 

2.设计思路

定义变量和输入循环次数及输入题目要求的数字,循环比较不断把最小的数赋给指定变量

(输入第一个数与一开始定义的0为最小数比较,比较小的数字作为目前的最小数,接着再与第二个数字进行比较),最后输出。

代码如下:

#include<stdio.h>
int main(){
	int n,i,min,a;
	scanf("%d",&n);
	scanf("%d",&a);
	min=a;
	for(i=1;i<n;i++){
		scanf("%d",&a);
		if(min>a)
		min=a;
		}
		printf("min = %d",min);
		return 0;
}

提交结果:

 

题目三:7-6

1.题目

2.提交列表

3.设计思路

定义相关变量和子函数,编写子函数(首先判断是否满足条件,满足继续,否则retrun 0,逐一判断素数,并返回其值),

再统计数目和求和。

4.流程图

代码如下

#include <stdio.h>  
#include <math.h>  
  
int prime(int num);  
  
int main()  
{  
    int i;  
    int M, N;  
    int sum = 0, cnt = 0;  
      
    scanf("%d%d", &M, &N);  
      
    for (i=M; i<=N; i++) {  
        if (prime(i)) {  
            sum += i;  
            cnt++;  
        }  
    }  
      
    printf("%d %d\n", cnt, sum);  
      
    return 0;  
}  
  
int prime(int num)  
{  
    int i;  
      
    if (num == 1)  
        return 0;  
      
    for (i=2; i<=sqrt(num); i++) {  
        if (num%i == 0) {  
            return 0;  
        }  
    }  
    return 1;  
}  

5.提交结果

四:同学互评

1.肥仔的代码

2.我的代码

#include<stdio.h>
int main(){
int n,i,min,a;
scanf("%d",&n);
scanf("%d",&a);
min=a;
for(i=1;i<n;i++){
scanf("%d",&a);
if(min>a)
min=a;
}
printf("min = %d",min);
return 0;
}

3..我和同学的代码有哪些不同?各自有哪些优势?你更喜欢那种代码的风格?

与他相比,我的代码更简洁,少了一重if选择,他的代码更通俗易懂,我的选择是最简洁的代码

四、本周学习总结

  1.本周你学会了什么?

   1.本周学会了for循环和while以及do....while 循环的基本运用

   2.以及深入了解了for和while循环嵌套

   3.for和while循环的判断条件等

--

转载于:https://www.cnblogs.com/scofieldying/p/8309529.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值