• B правой части каждого сообщения есть стрелки и . Не стесняйтесь оценивать ответы. Чтобы автору вопроса закрыть свой тикет, надо выбрать лучший ответ. Просто нажмите значок в правой части сообщения.

  • Курсы Академии Кодебай, стартующие в мае - июне, от команды The Codeby

    1. Цифровая криминалистика и реагирование на инциденты
    2. ОС Linux (DFIR) Старт: 16 мая
    3. Анализ фишинговых атак Старт: 16 мая Устройства для тестирования на проникновение Старт: 16 мая

    Скидки до 10%

    Полный список ближайших курсов ...

Строки На Си

  • Автор темы asoishnica
  • Дата начала
Статус
Закрыто для дальнейших ответов.
A

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();
}
 
Q

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(). Затем просто максимальный элемент в массиве найти.
 
Статус
Закрыто для дальнейших ответов.
Мы в соцсетях:

Обучение наступательной кибербезопасности в игровой форме. Начать игру!