2023/1/2
1.声明数组的时候要明确好size;
2.循环的时候注意,每轮循环过后,需不需要恢复原始数值;
3.malloc free 配对使用 不能忘记
上述三点例题
//一个数如果恰好等于不包含它本身所有因子之和,这个数就称为"完数"。 例如,6的因子为1、2、3,而6=1+2+3,因此6是"完数"。
//编程序找出N之内的所有完数,并按下面格式输出其因子
#include<stdio.h>
#include<stdlib.h>
int main()
{
int n=0;
scanf("%d",&n);
int a[10000];
int num;
//寻找n以内的完数
for(num=1;num<=n;num++){
int x=0;
int sum=0;
int i; //为下次循环做准备,每次恢复原始数值
//求因子 及和
for(i=1;i<num;i++){
if(num%i==0){
a[x++]=i;
sum+=i;
}
}
//判断是不是完数,输出
if(sum==num){
printf("%d its factors are ",num);
for(i=0;i<x;i++){
printf("%d ",a[i]);
}
printf("\n");
}
}
return 0;
}
4.宏定义 错题
下列程序运行结果为( )
#define P 3
#define S(a) P*a*a
int main()
{
int ar;
ar = S(3+5);
printf("\n%d", ar);
return 0;
}
A、192
B、25
C、29
D、27
「答案」C
「解题思路」本题考查对宏定义 #define 的理解,#define 在执行的时候,是直接替换的,本题中 S(3+5),展开后是:P*3+5*3+5,因为 P是 3, 所以表达式是 3*3+5*3+5=29,答案为 C。
如果想要先计算3+5,则需要define S(a) P*(a)*(a)