-1

我的程序有问题。这是一个问题:http ://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&problem=120

我有:

#include <stdio.h>
#include <stdlib.h>


typedef struct{

    int x,y;

} punkty;

typedef struct{

    punkty linia[300];
    int i;

}linie;

int sprawdzenie(punkty a, punkty b, punkty c)
{
        int n1, n2;

        if ((b.y-a.y)*(c.x-a.x)==(c.y-a.y)*(b.x-a.x))
            return 1;
        else
            return 0;

}

int sortowanie(punkty *proste, int roz)
{
  int i,j;

    for(i=0; i<roz;i++)
    {
        for(j=0; j<roz-1;j++)
        {
            if(proste[j].x>proste[j+1].x ||
                (proste[j].x == proste[j+1].x
                && proste[j].y>proste[j+1].y)
               )
            {
                punkty tmp;

                 tmp = proste[j];
                 proste[j] = proste[j+1];
                 proste[j+1] = tmp;
            }
        }


    }


}
int sortowanie_2(punkty *proste, int roz)
{
    int i,j;

    for(i=0; i<roz;i++)
    {
        for(j=0; j<roz-1;j++)
        {
            if(proste[j].x>proste[j+1].x ||
                (proste[j].x == proste[j+1].x
                && proste[j].y>proste[j+1].y)
               )
            {
                punkty tmp;

                 tmp = proste[j];
                 proste[j] = proste[j+1];
                 proste[j+1] = tmp;
            }
        }


    }

}

int duplikat(linie *proste, int roz, punkty a, punkty b, punkty c)
{
    int ax,k,j,i;


    for(ax=0;ax<roz;ax++)
        for(i=0;i<proste[ax].i-2;i++)
            for(j=i; j<proste[ax].i-1;j++)
                for(k=j;k<proste[ax].i;k++)

                    if(proste[ax].linia[i].x == a.x && proste[ax].linia[i].y == a.y &&
                       proste[ax].linia[j].x == b.x && proste[ax].linia[j].y == b.y &&
                       proste[ax].linia[k].x == c.x && proste[ax].linia[k].y == c.y
                       )
                    return 1;
    return 0;
}


int main()
{
    punkty tab[300];

    linie proste[300];

    int n=0,i,j,k,p=0,parametr=0;


/*wczytanie punktow*/

    while(scanf("%d %d", &tab[n].x, &tab[n].y) == 2  && (tab[n].x!=0 || tab[n].y!=0))
    {
        n++;
    }

    sortowanie(&tab,n);
/*wyszukiwanie lini */


    for(i=0; i<n-2;i++)
    {
        for(j=i+1; j<n-1; j++)
        {
            parametr=1;

            for(k=j+1; k<n; k++)
            {
                if(sprawdzenie(tab[i], tab[j], tab[k]) == 1 && duplikat(&proste, p, tab[i],tab[j],tab[k])==0)
                {

                    if(parametr==1)
                    {
                         //printf("x");
                         proste[p].linia[proste[p].i] = tab[i];
                         proste[p].i++;
                         proste[p].linia[proste[p].i] = tab[j];
                         proste[p].i++;
                         proste[p].linia[proste[p].i] = tab[k];
                         proste[p].i++;
                         parametr=0;
                    }
                    else
                    {
                        proste[p].linia[proste[p].i] = tab[k];
                        proste[p].i++;
                    }

                }
            }
            if(parametr==0)
            {
                p++;
            }
        }
    }

    if(p==0)
    {
        printf("No lines were found");
    }
    else
    {
        printf("The following lines were found:\n");
    }

    for(i=0; i<p; i++)
    {

        for(j=0; j<proste[i].i; j++)
        {
            printf("( %d, %d ) ", proste[i].linia[j].x,proste[i].linia[j].y);
           // printf("%d %d\n", tab[j].x, tab[j].y);
        }
        printf("\n");
    }



    getchar();
    return 0;
}

我有错误的程序:

code.c:在函数'main'中:code.c:116:5:警告:从不兼容的指针类型code.c:29:5传递'sortowane'的参数1:注意:预期'struct punkty '但参数是键入“struct punkty ( )[300]”code.c:128:17:警告:从不兼容的指针类型 code.c:81:5 传递“duplikat”的参数 1:注意:预期的“struct linie ”,但参数是键入“struct linie ( )[300]”code.c:133:26:错误:“/”标记之前的预期表达式 code.c:172:12:错误:“/”标记之前的预期表达式

4

1 回答 1

0
int sortowanie(punkty *proste, int roz)

需要一个 punkty 指针,但您正在传递一个punkty **,即指向指针的punkty指针:

punkty tab[300]; // tab is a (pointer to) array
sortowanie(&tab,n); // should be sortowanie(tab, n)

这里同样的问题:

linie proste[300];
duplikat(&proste, p, tab[i],tab[j],tab[k]) // should be duplikat(proste, ...

sortowanie_2中,你return什么都没有,你需要从这个函数返回一个整数。

但是编译器已经告诉你这些事情了。

于 2013-03-18T23:52:15.907 回答