Автор | Сообщение |
|
Отправлено: 07.02.22 20:15. Заголовок: Задание 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
[только новые]
|
|
|
Отправлено: 07.02.22 20:19. Заголовок: Количество пар получ..
Количество пар получилось 31
|
|
|
|
Отправлено: 17.06.22 14:31. Заголовок: Шмель пишет: Количе..
Шмель пишет: цитата: | Количество пар получилось 31 |
| и у меня тот же ответ (31) получился) вместо нечетности суммы цифр проверяла нечетность самого числа
|
|
|
|
| Администратор
|
Сообщение: 3281
|
|
Отправлено: 07.02.22 22:22. Заголовок: Чтобы оформить прогр..
Чтобы оформить программу, почитайте текст на желтом фоне вверху.
|
|
|
|
Отправлено: 08.02.22 00:02. Заголовок: f=open('17-8.tx..
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)
|
|
|
|
| Администратор
|
Сообщение: 3282
|
|
Отправлено: 09.02.22 10:48. Заголовок: Если вы не ошиблись ..
Если вы не ошиблись с номером задачи, то там написано такое условие: цитата: | Определите сначала количество пар элементов последовательности, в которых сумма цифр хотя бы одного из чисел в двоичной записи больше 5 и нечетна, а затем максимальную из сумм элементов таких пар. |
|
Имеется в виду, что нужно 1) перевести число в двоичную систему; 2) подсчитать в этой двоичной записи число единиц; 3) проверить, верно ли, что это число больше 5 и нечетное. А вот что вы проверяете: цитата: | if ((v>5) and (l%10==1)) or ((x>5) and (p%10==1)): |
|
Мне кажется, что это совершенно другое.
|
|
|
|
Отправлено: 09.02.22 21:16. Заголовок: На мой взгляд, не оч..
На мой взгляд, не очень корректно поставлено условие. Я поняла задачу так: 1) перевести число в двоичную систему; 2) найти сумму цифр полученного числа; 3) проверить заданные условия;
|
|
|
|
| Администратор
|
Сообщение: 3296
|
|
Отправлено: 10.02.22 16:43. Заголовок: Шмель пишет: На мой ..
Шмель пишет: цитата: | На мой взгляд, не очень корректно поставлено условие. Я поняла задачу так: 1) перевести число в двоичную систему; 2) найти сумму цифр полученного числа; 3) проверить заданные условия; |
|
Да, вы правы, это я не так понял условие. Вот решение: 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 )
|
|
|
|
Отправлено: 11.02.22 22:50. Заголовок: Спасибо!..
Спасибо!
|
|
|
|