我的功能有问题:

int parsearRestricciones(char linea[], unsigned int& x, unsigned int& y, unsigned int& tiempo, char restric[])


在该函数中,我解析linea []。

输入包含:三个无符号整数和一串标点字符。我需要那样阅读。
当我将atoi(linea + offset)分配给变量tiempo时,就会出现问题。在函数外部(即,在main()中),tiempo的值与其内部的值不同。
我只有在tiempo时才有问题(我用指向结构的指针替换了x,y和tiempo。

可能是什么问题呢?

谢谢你的帮助。

-----再次编辑

完整代码:

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <ctype.h>
#include <cassert>

#define MAX_RESTRIC 3  // Tres sentidos. Si hay 4, se usa '+'
#define MAX_LINEA 80
#define entrada cin


using namespace std;

int parsearRestricciones(char *linea, unsigned int& x, unsigned int& y, unsigned int& t, char *restric) {
// ! solo funciona si x,y,t,restric estan en una misma linea (i.e. no hay CR LF)

int i=0, j=0;

//Parsea x de la casilla
x = atol(linea+i);//strtol(linea,(char**)NULL,10);

while (isdigit(linea[i])) i++;
while (isspace(linea[i])) i++;

//Parsea y de la casilla
y = atol(linea+i);

while (isdigit(linea[i])) i++;
while (isspace(linea[i])) i++;
if(linea[i] == '\0')
    return -1;

//Parsea tiempo
t = atol(linea+i);
cout << "---" << t << endl;

while (!ispunct(linea[i])) i++;

//Parsea restricciones
while (linea[i] != '\0' && linea[i] != ' '){
    restric[j] = linea[i];
    i++; j++;
}
restric[j]='\0';

return 1;

}


int main (int argc, char** argv)
{
// Sugerencia de argumentos
// --d  (por Dijkstra)
// --axe  (por A*, distancia euclideana)
// --axm  (por A*, distancia manhattan)

// y dos màs que veremos luego :)

unsigned int X, Y;
unsigned int xi, yi;
unsigned int xf, yf;

unsigned int x,y,tiempo;

char restricciones[MAX_RESTRIC + 1];


//Buffer para parsear las lineas con restricciones
char linea[MAX_LINEA + 1];

bool finCasos = false;
bool siguienteCaso = false;


while (!finCasos)
{

    if (siguienteCaso){
        // Se leyó otro mapa antes que éste (hubo parseo, y quedo en xcasilla,ycasilla)
        X = x;
        Y = y;
        siguienteCaso = false;

    } else {
        // Sino, lee por primera vez las dimensiones del mapa
        entrada >> X >> Y;
    }

    if ( X == 0  &&  Y == 0 )
        finCasos = true;

    else {

        entrada >> xi >> yi;

        entrada >> xf >> yf;

        // Lee restricciones hasta que encuentra una linea sin ellas (sin tiempo ni direccion)
        // se asumira, que corresponde a las dimensiones del siguiente caso, y los usará en la siguiente
        // iteracion
        while(!siguienteCaso) {

            cin.get(); //lee un '\0' que quedó (?)
            cin.getline(linea, MAX_LINEA+1);

            if ( parsearRestricciones(linea,x,y,tiempo, restricciones) == -1 ) {
                siguienteCaso = true;

            } else {

                cout << "X = " << x << endl;
                cout << "Y = " << y << endl;
                cout << "tiempo = " << tiempo << endl;
                cout << "restric = " << restricciones << endl;
                int j=0;
                cout << "restric = " ;
                while(restricciones[j]!='\0'){
                    cout << restricciones[j];j++;}
                cout << endl;

                //-- agregar datos al grafo/mapa
            }

        }

        // Resolver usando algun algoritmo
        //--- resolver(MAPA)

    }

}


return 0;
}


CFLAGS。 -墙-管道-g -ggdb -DONLINE_JUDGE -DNDEBUG
(Makefile还为uvaonlinejudge构建了另一个源)

输入:

101
10
1
1
2
2
1000 10000  100000 +++++


输出:

---100000
X = 1000
Y = 10000
tiempo = 65579
restric = +++++
restric = +++++
^X^C (I did break)


我刚刚在Windows中测试了该程序(使用Code :: Blocks,默认设置),并且该程序有效:/

顺便说一句,我在Virtualbox中使用Ubuntu

你能告诉我我在做什么错吗?

最佳答案

我可以在C ++中通过引用传递多少个参数,而不会出现异常行为?

只要你想要的!

关于c++ - 我可以在C++中通过引用传递多少个参数,而不会出现异常行为,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/6561245/

10-13 06:59