Форум » Обработка целых чисел » Задание 17 № 4360 » Ответить

Задание 17 № 4360

Шмель: Неправильно считается количество пар, не могу найти ошибку в коде f=open('17-8.txt') c=f.readlines() a=[] j=0 maxi=0 for i in c: a.append(int(i)) for n in range(len(a)-1): b=0 d=0 g='' h='' t=0 w=0 v=0 x=0 l=0 p=0 a[n]=int(a[n]) a[n+1]=int(a[n+1]) b=a[n] d=a[n+1] #print(b,d) while b>0: g=str(b%2)+g b=b//2 while d>0: h=str(d%2)+h d=d//2 #print(g,h) g=int(g) h=int(h) t=g l=g w=h p=h while t>0: v+=t%10 t=t//10 while w>0: x+=w%10 w=w//10 #print(a[n],a[n+1],g,h,v,x) if ((v>5) and (l%10==1)) or ((x>5) and (p%10==1)): j+=1 if (a[n]+a[n+1])>maxi: maxi=a[n]+a[n+1] print(j, maxi)

Ответов - 8 новых

Шмель: Количество пар получилось 31

happysonc: Шмель пишет: Количество пар получилось 31 и у меня тот же ответ (31) получился) вместо нечетности суммы цифр проверяла нечетность самого числа

Поляков: Чтобы оформить программу, почитайте текст на желтом фоне вверху.


Шмель: [pre2] f=open('17-8.txt') c=f.readlines() a=[] j=0 maxi=0 for i in c: a.append(int(i)) for n in range(len(a)-1): b=0 d=0 g='' h='' t=0 w=0 v=0 x=0 l=0 p=0 a[n]=int(a[n]) a[n+1]=int(a[n+1]) b=a[n] d=a[n+1] #print(b,d) while b>0: g=str(b%2)+g b=b//2 while d>0: h=str(d%2)+h d=d//2 #print(g,h) g=int(g) h=int(h) t=g l=g w=h p=h while t>0: v+=t%10 t=t//10 while w>0: x+=w%10 w=w//10 #print(a[n],a[n+1],g,h,v,x) if ((v>5) and (l%10==1)) or ((x>5) and (p%10==1)): j+=1 if (a[n]+a[n+1])>maxi: maxi=a[n]+a[n+1] print(j, maxi) [/pre2]

Поляков: Если вы не ошиблись с номером задачи, то там написано такое условие: Определите сначала количество пар элементов последовательности, в которых сумма цифр хотя бы одного из чисел в двоичной записи больше 5 и нечетна, а затем максимальную из сумм элементов таких пар.Имеется в виду, что нужно 1) перевести число в двоичную систему; 2) подсчитать в этой двоичной записи число единиц; 3) проверить, верно ли, что это число больше 5 и нечетное. А вот что вы проверяете: if ((v>5) and (l%10==1)) or ((x>5) and (p%10==1)): Мне кажется, что это совершенно другое.

Шмель: На мой взгляд, не очень корректно поставлено условие. Я поняла задачу так: 1) перевести число в двоичную систему; 2) найти сумму цифр полученного числа; 3) проверить заданные условия;

Поляков: Шмель пишет: На мой взгляд, не очень корректно поставлено условие. Я поняла задачу так: 1) перевести число в двоичную систему; 2) найти сумму цифр полученного числа; 3) проверить заданные условия; Да, вы правы, это я не так понял условие. Вот решение:[pre2] data = [int(x) for x in open('17-8.txt')] def valid( n ): s = sum(map( int, bin(n)[2:] )) return s > 5 and s % 2 == 1 count, ma = 0, 0 for i, n in enumerate(data): if i > 0: if valid(data[i-1]) or valid(data[ i]): count += 1 ma = max(ma, data[i-1] + data[ i] ) print( count, ma )[/pre2]

Шмель: Спасибо!



полная версия страницы