我试图通过使用c上的结构来解决问题。
它应该找出3个值中最大的一个,如果它是素数,则将其他所有值相加。如果不是,就把最大的数返回给main函数。我找不到哪里出错了。
#include <stdio.h>
#include <stdlib.h>
struct q {
int a, b, c, max;
}d;
func(struct q d1)
{
int max1;
max1=0;
int w=0;
int i;
if (d1.a>d1.b && d1.a>d1.c)
max1=d1.a;
if (d1.b>d1.a && d1.b>d1.c)
max1=d1.b;
if (d1.c>d1.b && d1.c>d1.a)
max1=d1.c;
for(i=2;i<max1;i++)
{
if (max1%i==0)
w=1;
}
if (w==0)
{
d1.a=d1.a+max1;
d1.b=d1.b+max1;
d1.c=d1.c+max1;
}
if (w==1)
{
d1.max=max1;
}
}
int main()
{
int i;
for(i=0;i<1;i++)
{
d.max=0;
puts("enter value of a b c:");
scanf("%d %d %d",&d.a,&d.b,&d.c);
func(d);
if(d.max==0) printf("%d %d %d",d.a,d.b,d.c);
else printf("%d",d.max);
}
}
我不确定算法逻辑。但错误是-
func(struct q d1)
func(d);
d1
是传递参数d
的副本。因此,修改d1
,不影响传递参数d
。
实际上应该将对象d
的地址传递给函数。
在func()中你必须传递结构的地址…因为如果你只传递struct变量那么它的值会受到影响直到缓冲区只有。