作业1
输出从起始值到终止值之间,所有能被3或5整除的所有数,起始值和终止值由用户输入.
#include <stdio.h>
int main(int argc, char * argv[])
{
// 输出从起始值到终止值之间,
// 所有能被3或5整除的所有数,
// 起始值和终止值由用户输入.
int start, end;
printf("请输入起始值:");
scanf("%d", &start);
printf("请输入终止值:");
scanf("%d", &end);
for (int i = start; i <= end; i++) {
if (i % 3 == 0 || i % 5 == 0) {
printf("%d\n", i);
}
}
return 0;
}
作业2
输出斐波那契前20项的值 :
斐波那契数列:
1 1 2 3 5 8 13 。。。
#include <stdio.h>
int main(int argc, const char * argv[])
{
// 输出斐波那契前20项的值
int a = 1, b = 1;
for (int i = 0; i < 20; i++) {
printf("%d ", a);
int tmp = a + b;
a = b;
b = tmp;
}
printf("\n");
return 0;
}
作业3
输入一个数,判断该数是否为素数(只能被1和其本身整除的数)
#include <stdio.h>
int main(int argc, char * argv[])
{
//输入一个数,判断该数是否为素数
int num, cond = 1;
printf("请输入一个数: ");
scanf("%d", &num);
for (int i = 2; i < num; i++) {
if(num % i == 0) {
cond = 0;
break;
}
}
// 素数从 2 开始
printf(num > 1 && cond ? "该数是素数\n": "该数不是素数\n");
return 0;
}
作业4
输入一个数,判断该数是否为完美数(所有真因子之和等于其本身,例如:6 = 1+2+3)
#include <stdio.h>
int main(int argc, char * argv[])
{
// 输入一个数,判断该数是否为完美数
int num, sum = 0; // sum 为因子数的和
printf("请输入一个数:");
scanf("%d", &num);
for (int i = 1; i < num; i++)
if (num % i == 0)
sum += i;
if (sum == num)
printf("%d是完美数\n", num);
else
printf("%d不是完美数\n", num);
return 0;
}
作业5
输出起始值到终止值之间所有的素数
#include <stdio.h>
int main(int argc, char * argv[])
{
// 输出起始值到终止值之间所有的素数
int start, end;
printf("请输入起始值:");
scanf("%d", &start);
printf("请输入终止值:");
scanf("%d", &end);
for (int num = start; num <= end; num++) {
int flag = 1; // 记录判断值, 1代表是素数
for (int i = 2; i < num; i++) {
if (num % i == 0) {
flag = 0;
break;
}
}
// 素数从 2 开始
if(num > 1 && flag) printf("%d\n", num);
}
return 0;
}
作业6
输出起始值到终止值之间所有的完美数
#include <stdio.h>
int main(int argc, char * argv[])
{
// 输出起始值到终止值之间所有的完美数
int start, end;
printf("请输入起始值:");
scanf("%d", &start);
printf("请输入终止值:");
scanf("%d", &end);
for (int num = start; num <= end; num++) {
int sum = 0; // 因子数之和
for (int i = 1; i < num; i++)
if (num % i == 0)
sum += i;
if (sum == num) printf("%d\n", num);
}
}