Строки На Си

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

asoishnica

Гость
#1
Найти все цепочки символов , являющиеся записями целых чисел по основанию 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

Гость
#3
Сформулируй условие более понятно
А чего непонятного? Все ясно.

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

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