关于C语言结构体的算法



我试图通过使用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变量那么它的值会受到影响直到缓冲区只有。

相关内容

  • 没有找到相关文章

最新更新