-
-
Save luizomf/daa038e6b02d8cba125d87a28e66ec8b to your computer and use it in GitHub Desktop.
""" | |
Considerando duas listas de inteiros ou floats (lista A e lista B) | |
Some os valores nas listas retornando uma nova lista com os valores somados: | |
Se uma lista for maior que a outra, a soma só vai considerar o tamanho da | |
menor. | |
Exemplo: | |
lista_a = [1, 2, 3, 4, 5, 6, 7] | |
lista_b = [1, 2, 3, 4] | |
=================== resultado | |
lista_soma = [2, 4, 6, 8] | |
""" | |
lista_a = [10, 2, 3, 40, 5, 6, 7] | |
lista_b = [1, 2, 3, 4] | |
lista_soma = [x + y for x, y in zip(lista_a, lista_b)] | |
print(lista_soma) | |
# lista_soma = [] | |
# for i in range(len(lista_b)): | |
# lista_soma.append(lista_a[i] + lista_b[i]) | |
# print(lista_soma) | |
# lista_soma = [] | |
# for i, _ in enumerate(lista_b): | |
# lista_soma.append(lista_a[i] + lista_b[i]) | |
# print(lista_soma) |
alfanascimento
commented
Feb 1, 2024
•
def soma(lista_a, lista_b):
intervalo_max = min(len(lista_a), len(lista_b))
return [
(lista_a[indice] + lista_b[indice])
for indice in range(intervalo_max)
]
lista_a = [1, 2, 3, 4, 5, 6, 7]
lista_b = [1, 2, 3, 4]
lista_soma = soma(lista_a, lista_b)
print(lista_soma)
result = print(f'O resultado final eh: {lista_soma}')
lista_a = [1, 2, 3, 4, 5, 6, 7]
lista_b = [1, 2, 3, 4]
lista_soma = []
range_min = 1
if len(lista_a) > len(lista_b):
range_min = len(lista_b)
else:
range_min = len(lista_a)
for i in range(range_min):
lista_soma.append(lista_a[i] + lista_b[i])
print(lista_soma)
lista_a = [10, 2, 3, 40, 5, 6, 7]
lista_b = [1, 2, 3, 4]
tamanhoListaA = len(lista_a)
tamanhoListaB = len(lista_b)
menorLista = 0
if tamanhoListaA < tamanhoListaB:
menorLista = tamanhoListaA
else:
menorLista = tamanhoListaB
lista_c = []
i = 0
for numero in range(menorLista):
numero_nova_lista = lista_a[i]+ lista_b[i]
lista_c.append(numero_nova_lista)
i += 1
print(lista_c)
Tentei usar decoradores, mas não consegui. Então fiz uma função simples mesmo.
lista_a = [1, 2, 3, 4, 5, 6, 7]
lista_b = [1, 2, 3, 4]
def somar_itens_lista(lista_a, lista_b):
if len(lista_a) > len(lista_b):
intervalo = len(lista_b)
else:
intervalo = len(lista_a)
return [
(lista_a[i] + lista_b[i]) for i in range(intervalo)
]
print(somar_itens_lista(lista_a, lista_b))
lista_a = [1, 2, 3, 4, 5, 6, 7]
lista_b = [1, 2, 3, 4]
listaZip = list(zip(lista_a, lista_b))
lista_somada = [a + b for a, b in listaZip]
print(lista_somada)
lista_a = [10, 2, 3, 40, 5, 6, 7]
lista_b = [1, 2, 3, 4]
resultado = []
listab_destrinchada = iter(lista_b)
for item in lista_a:
try:
item += listab_destrinchada.__next__()
#print(item) # Propósitos de testes
resultado.append(item)
except StopIteration:
#print(item) # Propósitos de testes
resultado.append(item)
print("A soma da listaA: ")
print(lista_a)
print("+")
print("listaB: ")
print(lista_b)
print("= ")
print(resultado)
list_a = [i for i in range(1, 8)]
list_b = [i for i in range(1, 5)]
def sum_list(lst1, lst2):
interval = min(len(lst1), len(lst2))
return [
lst1[i] + lst2[i]
for i in range(interval)
]
print(sum_list(list_a, list_b))
Função que soma diversas listas
def sum_lists(*args):
return [sum(args) for args in zip(*args)]
print(sum_lists(list_a, list_b, list_c))
lista_a = [1, 2.8, 3, 4, 5, 6, 7]
lista_b = [1, 2, 3, 4]
def somando_valores(l1, l2):
menor_valor = min(len(l1), len(l2))
if len(l1) <= len(l2):
return [l1[i] + l2[i] for i in range(menor_valor)]
elif len(l2) < len(l1):
return [l2[i] + l1[i] for i in range(menor_valor)]
else:
return "Não sei como chegou aq"
print(somando_valores(lista_a, lista_b))
list_a = [1, 2, 3, 4 ,5 ,6, 7]
list_b = [1, 2, 3, 4]
def List_sum(list1, list2):
size = min(len(list1),len(list2))
return[
list1[i] + list2[i] for i in range(size)
]
print(List_sum(list_a, list_b))
l1 = [1, 2, 3, 4, 5, 6, 7]
l2 = [1, 2, 3, 4]
def sum_list(list1, list2):
list_sum = []
value_min = min(list1, list2)
for x in range(len(value_min)):
new_list = list1[x] + list2[x]
list_sum.append(new_list)
return list_sum
print(sum_list(l1, l2))
def criar_funcao(func):
def interna(*args, **kwargs):
for arg in args:
is_int(arg)
resultado = func(*args, **kwargs)
return resultado
return interna
def is_int(param):
if not isinstance(param, int):
raise TypeError('param deve ser um int')
@criar_funcao
def soma(a, b):
return a + b
def zipper(lista1, lista2):
intervalo = min(len(lista1), len(lista2))
return [
soma(lista1[i],lista2[i]) for i in range(intervalo)
]
lista_a = [1, 2, 3, 4, 5, 6, 7]
lista_b = [1, 2, 3, 4]
print(list(zipper(lista_a, lista_b)))