int *finish_plus(int m,int n)//寻找完数plus
{
int sum_plus;
static int arr[100] = { 0 };//这里我们使用了static关键字,使得数组的生命期延长到整个流程,因此我们就可以取他的地址
int temp = 0;
for (int i = m; i <= n; i++)
{
sum_plus = 0;
int temp1 = sqrt(i);
for (int k = 1; k < temp1; k++)
{
if (i % k == 0)
{
sum_plus += k;
}
}
for (int t = 2; t <= temp1+1; t++)
{
if (i % t == 0)
{
sum_plus += i / t;
}
}
if (sum_plus == i)
{
arr[temp+1] = sum_plus;
temp++;
}
}
arr[0] = temp;//arr[0]就可以代表了输出的次数了
int *p = arr;//*p获取已经被static修饰的数组arr地址
return p;//返回的是arr数组首地址
}
c语言static的简单应用
最新推荐文章于 2023-08-01 15:49:05 发布