#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循环的判断条件等

--

posted @ 2018-01-18 12:16  陈兴颖  阅读(386)  评论(0编辑  收藏  举报