编译器遇到点问题,没办法下手。
算是查漏补缺吧,学习过程中遇到点问题,但又不知道是哪方面的知识。#include<stdio.h>
int number(int n)
{
int test = { 0 }, i;
for (i = 0; i<n; i++)
{
test = 1;
test = i + 1;
}
//for (i = 0; i<n; i++)
// printf("%i\n", test);
return test;
}
int main()
{
//int number[] = { 0,2,4,3,2,6,5,2,4,6,7,5,7 };
int i;
int n;
int j;
scanf_s("%d", &n);
int *p = number(n);
for ( i = 1; i < n; i++)
{
for ( j = 2; j <= i; j++)
{
if (*(p+i)%j==0)
{
break;
}
if (*(p + i) == (j+1))
{
printf("%d\n", *(p + i));
break;
}
}
}
}
遇到的警告是C4047,C4172,想研究一下怎么去掉警告,但无从下手。
还有就是我打印素数的时候中间断了,用的VS2013.
727
733
739
743
811
823
823
3
887
,743和811之间还有素数的,但是他不打印,还有就是不知道为什么下面有个3 代码是输入n,打印0到n之间的素数。 本帖最后由 永恒的蓝色梦想 于 2020-4-28 07:48 编辑
返回值写int*,再把test变成static就可以了#include<stdio.h>
int* number(int n)
{
static int test = { 0 };
for (int i = 0; i < n; i++)
{
test = 1;
test = i + 1;
}
return test;
}
int main()
{
int i;
int n;
int j;
scanf_s("%d", &n);
int* p = number(n);
for (i = 1; i < n; i++)
{
for (j = 2; j <= i; j++)
{
if (*(p + i) % j == 0)
{
break;
}
if (*(p + i) == (j + 1))
{
printf("%d\n", *(p + i));
break;
}
}
}
} 这不是编译器的问题,是你的程序有问题。
number函数返回的是一个局部变量,当number函数结束的时候,test就被回收释放了。所以指针p指向的对应单元很有可能已经不再是你在number函数中的赋值了。
再者,你的number函数的返回类型也不对啊。应该是返回int*
在你的程序基础上帮你修改了
#include<stdio.h>
int* number(int n)
{
static int test = { 0 };
int i;
for (i = 0; i<n; i++)
{
test = i + 1;
}
//for (i = 0; i<n; i++)
// printf("%i", test);
return test;
}
int main()
{
//int number[] = { 0,2,4,3,2,6,5,2,4,6,7,5,7 };
int i;
int n;
int j;
scanf_s("%d", &n);
int *p = number(n);
for ( i = 1; i < n; i++)
{
for ( j = 2; j <= i; j++)
{
if (*(p+i)%j==0)
{
break;
}
if (*(p + i) == (j+1))
{
printf("%d\n", *(p + i));
break;
}
}
}
}
页:
[1]