Как читать из ввода, пока новая строка не найдена с помощью scanf ()? - PullRequest
17 голосов
/ 11 ноября 2011

Меня попросили выполнить работу в C, когда я должен читать с ввода, пока не будет пробела, а затем, пока пользователь не нажмет ввод.Если я сделаю это:

scanf("%2000s %2000s", a, b);

Это будет следовать 1-му правилу, но не 2-му.
Если я напишу:

I am smart

То, что я получу, эквивалентно:
a = "I";
b = "am";
Но это должно быть:
a = "I";
b = "am smart";

Я уже пробовал:

scanf("%2000s %2000[^\n]\n", a, b);

и

scanf("%2000s %2000[^\0]\0", a, b);

В первом из них пользователь ждет нажатия Ctrl + D (чтобы отправить EOF) и это не то, что я хочу.Во втором он не скомпилируется.Согласно компилятору:

предупреждение: не закрывать ']' для '% [' format

Есть какой-нибудь хороший способ решить эту проблему?

Ответы [ 7 ]

36 голосов
/ 11 ноября 2011

scanf (и двоюродные братья) имеют одну немного странную характеристику: любое пустое пространство в строке формата (за пределами набора сканирования) соответствует произвольному количеству пустого пространства на входе. Как это происходит, по крайней мере в локали по умолчанию "C", новая строка классифицируется как пробел.

Это означает, что конечный '\n' пытается найти соответствие не только a новой строки, но и любому последующему пробелу. Он не будет считаться совпадающим до тех пор, пока вы не укажете конец ввода или не введете какой-либо непробельный символ.

Чтобы справиться с этим, вы обычно хотите сделать что-то вроде этого:

scanf("%2000s %2000[^\n]%c", a, b, c);

if (c=='\n')
    // we read the whole line
else
    // the rest of the line was more than 2000 characters long. `c` contains a 
    // character from the input, and there's potentially more after that as well.
7 голосов
/ 11 ноября 2011
scanf("%2000s %2000[^\n]", a, b);
4 голосов
/ 11 ноября 2011

используйте getchar и какое-то время выглядят так

while(x = getchar())
{   
    if(x == '\n'||x == '\0')
       do what you need when space or return is detected
    else
        mystring.append(x)
}

Извините, если я написал псевдокод, но некоторое время не работаю с языком Си.

2 голосов
/ 16 сентября 2016

Я опоздал, но вы также можете попробовать этот подход.

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

int main() {
    int i=0, j=0, arr[100];
    char temp;
    while(scanf("%d%c", &arr[i], &temp)){
        i++;
        if(temp=='\n'){
            break;
        }
    }
    for(j=0; j<i; j++) {
        printf("%d ", arr[j]);
    }

    return 0;
}
2 голосов
/ 19 октября 2014
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>

int main(void)
{
  int i = 0;
  char *a = (char *) malloc(sizeof(char) * 1024);
  while (1) {
    scanf("%c", &a[i]);
    if (a[i] == '\n') {
      break;
    }
    else {
      i++;
    }
  }
  a[i] = '\0';
  i = 0;
  printf("\n");
  while (a[i] != '\0') {
    printf("%c", a[i]);
    i++;
  }
  free(a);
  getch();
  return 0;
}
0 голосов
/ 28 апреля 2018
#include <stdio.h>
int main()
{
    char a[5],b[10];
    scanf("%2000s %2000[^\n]s",a,b);
    printf("a=%s b=%s",a,b);
}

Просто напишите s вместо \ n:)

0 голосов
/ 11 ноября 2011

Звучит как домашнее задание.scanf () - неправильная функция для решения проблемы.Я бы порекомендовал getchar () или getch ().

Примечание: я намеренно не решаю проблему, так как это похоже на домашнюю работу, вместо этого я просто указываю вам в правильном направлении.

...