Строки На Си

Тема в разделе "C/C++/C#", создана пользователем asoishnica, 4 мар 2012.

Статус темы:
Закрыта.
  1. asoishnica

    asoishnica Гость

    Найти все цепочки символов , являющиеся записями целых чисел по основанию 8 и найти цепочку , являющуюся записью наибольшего числа.
    #include<stdio.h>
    #include<conio.h>
    #include<math.h>
    #include<string.h>
    void main()
    {
    char str[100]={0};
    char tst[100]={0}, max=0;
    int i=0,n;
    clrscr();
    puts("Vvedite stroku");
    gets(str);
    for(i=0;str!='\0';i++)
    {while(str=='0' || str=='1'){
    if(tst[100]==0) tst=str;}
    n=(int)tst;
    if(n>max){ max=n; memset(tst, 0, sizeof(int)*100);}

    }
    printf("%d",max);
    getch();
    }
     
  2. Whatka

    Whatka Well-Known Member

    Регистрация:
    9 окт 2011
    Сообщения:
    433
    Симпатии:
    4
    Сформулируй условие более понятно
     
  3. qqwertty

    qqwertty Гость

    А чего непонятного? Все ясно.

    Не работает потому что вот здесь у вас бесконечный цикл:

    Код (C++):
    while (str[i]=='0' || str[i]=='1'){
    if(tst[100]==0) tst[i]=str[i];}
    n=(int)tst;
    if(n>max){ max=n; memset(tst, 0, sizeof(int)*100);}
    Мне вообще смысл этих строк не понятен. Фактически тут ничего не делается.
    Вам нужно разбить строку на последовательности: искать до пробела и плюс если в последовательности не встречаются символы: 8, 9 и все остальные символы. Для этого можно формировать отдельную строку (ваш tst[100]). Затем записывать число в массив (int chisla[100], ну например), используя функцию atoi(). Затем просто максимальный элемент в массиве найти.
     
Загрузка...
Статус темы:
Закрыта.

Поделиться этой страницей