Дополнительные нули в начале оператора печати, когда некоторые недопустимые входные данные, которые не являются целыми числами - PullRequest
0 голосов
/ 01 марта 2019

Я должен был создать программу, которая сортировала бы массив целых чисел, заданных из командной строки, в то время как моя программа ниже, кажется, делает это прекрасно, даже с проверкой ошибок. Я столкнулся с проблемой, которую я путаю с тем, почему это происходит.Когда я делаю тестовый случай ./permarray 22 3d test2 1 -5 5 0 -29 2, я получаю вывод, что, хотя он правильно сортирует числа и печатает, что 3d и test2 не являются целыми числами, он помещает два 0 в начале этого оператора печати.Почему это происходит из-за того, как я проверяю ошибки для этих недопустимых операторов?

permarray_main.c

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

int permarray(int* arr, size_t len);
int main(int argc, char *argv[])
{
    bool any_valid = false;   
    int i;
    if(argc > 1){
        int *arr = NULL;
        char *endptr = NULL;
        int check, sum;
        size_t len = (size_t)argc-1;

        arr = malloc(len * sizeof *arr);
        for(i = 0; i < len; i++){
            check = strtol(argv[i+1], &endptr, 10);
            if(endptr != argv[i+1] && *endptr == '\0'){
                arr[i] = check;
                any_valid = true;
            }else{
                fprintf(stderr, "Error: %s is not a valid integer!\n", argv[i+1]);
            }

        }
        if(any_valid){
        permarray(arr, len);
        }


      }else{
          fprintf(stderr, "Error: Expected a list of integers as arguments!\n");
      }
    }

permarray.c

int permarray(int a[], int l)
{
    int i,j,t,k;
for(i=0,j=0;i<l;i++)
   {
    if(a[i]>0)
    continue;
    else
       {
        t=a[i]; //swapping positive elements at beginning with negative ones
        a[i]=a[j];
        a[j]=t;
        j++;
       }
     }


   for(i=j;i<l-1;i++) //starting from positive values
   {
    for(k=i+1;k<l;k++)
    {
     if(a[i]>a[k])
      {
      t=a[i]; //bubble sorting
      a[i]=a[k];
      a[k]=t;
       }
      }
     }
for(i=0;i<l;i++){
printf("%d ",a[i]);
}
printf("\n");
}

ТЕКУЩИЙ ВЫХОД

Error: 3d is not a valid integer!
Error: test2 is not a valid integer!
0 0 -5 0 -29 1 2 5 22

Желаемый выход

Error: 3d is not a valid integer!
Error: test2 is not a valid integer!
-5 0 -29 1 2 5 22

1 Ответ

0 голосов
/ 01 марта 2019

Неудачные преобразования должны эффективно уменьшить len в сортировке.

  int n = 0;  // Count valid conversions.
  for (i = 0; i < len; i++) {
    check = strtol(argv[i+1], &endptr, 10);
    if (endptr != argv[i+1] && *endptr == '\0') {
      // arr[i] = check;
      arr[n++] = check;
    } else {
      fprintf(stderr, "Error: %s is not a valid integer!\n", argv[i+1]);
    }
  }

  if(n > 0) {
    permarray(arr, n);
  }


// for (i=0;i<l;i++){
for (i=0;i<n;i++){
  printf("%d ",a[i]);
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...