Como obter todo o inteiros de arquivo tem strings e inteiros e armazená-los na matriz em C ++?

votos
0

Eu quero obter números inteiros de arquivo que tem cordas também, e armazená-los em conjunto para fazer alguma operação sobre eles. os números inteiros podem ser 1 ou 12 ou 234, de modo 3 dígitos. Eu estou tentando fazer isso, mas a saída pára quando eu executar o código

void GetNumFromFile (ifstream &file1, char & contents)
{
    int digits[20];
    file1.get(contents);
    while(!file1.eof())
    {
        for (int n = 0; n < 10; n++)
        {
        if(('0' <= contents && contents <= '9') && ('0' >= contents+1 && contents+1 > '9'));
            digits[n]=contents;
        if(('0' <= contents && contents <= '9') && ('0' <= contents+1 && contents+1 < '9'));
            digits[n]=contents;
        if(('0' <= contents && contents <= '9')&&('0' <= contents+1 && contents+1 <= '9')
         && ('0' <= contents+2 && contents+2 < '9'));
            digits[n]=contents;
        }
        continue;
    }
        for (int i = 0; i <= 20; i++)
            {
            cout << *(digits + i) << endl;
            }

}
Publicado 10/10/2019 em 01:02
fonte usuário
Em outras línguas...                            


3 respostas

votos
0

Você tem que lidar com o número de dígitos do número encontrado:

int digits[20];
int i = 0;
short int aux[3]; // to format each digit of the numbers

ifstream file1("filepath");
char contents;

file1.get(contents); //first char

while (!file1.eof())
{
    if (contents <= '9' && contents >= '0' && i < 20) // if character is in number range
    {
        aux[0] = contents - '0'; // converting the char to the right integer
        file1.get(contents);

        if ((contents <= '9' && contents >= '0' && i < 20) && !file1.eof()) // if is integer and has mor char to read, continue on
        {
            aux[1] = contents - '0';
            file1.get(contents);
            if ((contents <= '9' && contents >= '0' && i < 20) && !file1.eof()) // if is integer and has mor char to read, continue on
            {
                aux[2] = contents - '0';
                file1.get(contents);
                aux[0] *= 100; // define houndred
                aux[1] *= 10; // define ten
                digits[i++] = aux[0] + aux[1] + aux[2];

            }
            else
            {
                aux[0] *= 10; // define ten
                digits[i++] = aux[0] + aux[1];
            }
        }
        else
        {
            digits[i++] = aux[0];
        }
    }
    i++;
}

Se você quiser ler um número de tamanho indefinido, então você vai ter que alocar memória para formatar cada dígito dos numers com o novo (c ++) ou malloc (c / c ++).

Respondeu 10/10/2019 em 05:06
fonte usuário

votos
0

Você vai precisar primeiro a adicionar get()funcionalidade dentro do loop, assim, a fim de chegar a final do arquivo.

Forthmore tentar adicionar um loop while uma vez por charfoi encontrado para ser um inteiro para continuar em pedir o próximo caractere.

por exemplo

int digits[20];
int i = 0;
ifstream file1("filepath");
char contents;
while (!file1.eof())
{
    file1.get(contents); // get the next character

    if (contents <= '9' && contents >= '0' && i < 20) // if character is in number range
    {
        digits[i++] = contents - '0'; // converting the chat to the right integer
        file1.get(contents);

        while (contents <= '9' && contents >= '0' && i < 20) // while is integer continue on
        {
            digits[i++] = contents - '0';
            file1.get(contents);
        }
    }
}

// do other stuff here
Respondeu 10/10/2019 em 02:29
fonte usuário

votos
0

Primeira observação: você iterar fora dos limites da matriz:

int digits[20];
for (int i = 0; i <= 20; i++)

20 e elementos 21 de iteração. Isso é um comportamento indefinido, então tudo é possível aqui (se o seu programa, eventualmente, chegar aqui).

Em seguida, você ler a partir de arquivo de uma vez e então você tem um loop infinito, porque a expressão !file1.eof()é verdadeira ou falsa para o resto da execução do programa. Não é essa a razão de "paradas de saída"?

A terceira constatação: as ifdeclarações são inúteis por causa do ponto e vírgula após a declaração:

if(('0' <= contents && contents <= '9') && ('0' >= contents+1 && contents+1 > '9'));
            digits[n]=contents;

Você acabou de atribuir digits[n]=contents;sem qualquer verificação.

Eu não vejo nenhuma razão de fornecer uma referência para char na função. Por que não torná-lo uma variável local?

Respondeu 10/10/2019 em 01:31
fonte usuário

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more