Checking odd numbers python - python

I'm stuck on this question for checking odd numbers, with for loop method
I've been given part of this code to produce odd numbers only
def get_odds(items):
new_list = []
return new_list
If anyone can help, that would be great - thanks!

You can use a list comprehension:
def get_odds(items):
new_list = [item for item in items if item % 2 == 1]
return new_list
Edit: If you have to use a for loop, you can write something in the lines of:
def get_odds(items):
new_list = []
for item in items:
if item % 2 == 1:
new_list.append(item)
return new_list
As you will see, this is just a longer way of writing the first solution.

How about
for a in range(10000):
if a%2==1:
new_list.append(a)
I am sure there are better algorithms but it is early and I have not had an coffee yet :)

def get_odds(items):
new_list = [] ###create an empty container to store odd no.s when passed into it
for item in items: ### loop over your items (a list probably)
if item%2 != 0: ####here u will get odd numbers(Yes ==1 also works)
new_list.append(item)
return new_list
Note: though List comprehension are more pythonic way, but a for loop is easy to understand logic.

l = lambda(y) : [i for i in xrange(y) if i%2!=0]
print l(1000)
Or simply
odd_list = [i for i in xrange(1000) if i%2!=0]

Related

Insert after each occurrence - Python

How to write a function that does the following -
After each occurrence of num1 in a list, insert num2
def insert_after(lst, num1, num2):
In general, people on stack overflow would appreciate you to at least attempt a solution before asking for help. That being said, here is an O(1) solution that is the first to come to mind:
PREVIOUS ANSWER WAS INCORRECT
The best way to do this is as follow:
Iterating through the length of the list as I did before does not work, as the list is growing when you insert but you are iterating through a fixed number.
def insert_after(lst,num1,num2):
output = []
for num in lst:
output.append(num)
if num == num1:
output.append(num2)
return output
Here are a couple fun ways using list comprehensions:
Solution 1:
lst = [1,5,4,3,5,5,7,8,9,6,5]
def insert_after_more_readable(lst,num1,num2):
temp_lst = [[num] if num != num1 else [num, num2] for num in lst]
final_lst = [elem for sublist in temp_lst for elem in sublist]
return final_lst
print(lst, 5,8)
Explanation:
We create a list of lists called temp_lst. Every time we encounter num1, we insert a sublist [num1,num2], and otherwise we insert sublist [num].
We iterate over all the sublists, and take out all their elements and put them into the outer list.
Solution 2:
This is a less readable version, but the exact same thing using nested list comprehensions, all in one line.
lst = [1,5,4,3,5,5,7,8,9,6,5]
def insert_after(lst, num1, num2):
return [elem for sublist in [[num] if num != num1 else [num,num2]
for num in lst] for elem in sublist]
print(lst, 5,8)
In this version, the inner list that is formed is equivalent to temp_lst above.

How to handle operating on items in a list without perfectly even len()?

I'm trying to operate on every 5 items in a list, but can't figure out how to handle the remaining items if they don't divide evenly into 5. Right now I'm using modulo, but I can't shake the feeling it's not quite the right answer. Here's an example...
list = ["ValA","ValB","ValC","ValD","ValE","ValF","ValG","ValH","ValI","ValJ","ValK","ValL","ValM","ValN",]
newlist = []
i = 0
for o in list:
i += 1
newlist.append(o)
if i % 5 == 0:
for obj in newlist:
function_for(obj)
newlist.clear()
This code will execute function_for() twice, but not a third time to handle the remaining 4 values. If I add an 'else' statement it runs on every execution.
What's the correct way to handle a situation like this?
This way is pretty easy, if you don't mind modifying the list:
mylist = ["ValA","ValB","ValC","ValD","ValE","ValF","ValG","ValH","ValI","ValJ","ValK","ValL","ValM","ValN",]
while mylist:
function_for( mylist[:5] )
mylist = mylist[5:]
You can also check if the index is equal to the length of the list. (Additionally, it is more idiomatic to use enumerate instead of a counter variable here.)
lst = ["ValA","ValB","ValC","ValD","ValE","ValF","ValG","ValH","ValI","ValJ","ValK","ValL","ValM","ValN",]
newlist = []
for i, o in enumerate(lst, 1):
newlist.append(o)
if i % 5 == 0 or i == len(lst):
print(newlist)
newlist.clear()

Parsing through a list to find a sequence of numbers

I have a list of numbers and I want to check if a definite sequence exists in that list. For example, for [1,1,2,2,3,3,3,4,5,5,6] how can I determine if the sequence 3-4-5 exists?
I tried using nested loops, but ran into a problem with break/continue. I am now reducing the list to its unique elements and seeing if my sequence exists:
ls = [1,1,2,2,3,3,3,4,5,5,6]
uniq_ls = []
for item in ls:
if item not in uniql:
uniq_ls.append(item)
for ii, item in enumerate(uniq_ls):
if item == 3:
if uniq_ls[ii+1] == 4:
if uniq_ls[ii+2] == 5:
print('yes, sequence exists')
Above method works, but I want to do this without reducing the original list to its unique elements.
How can I do this?
As pointed out by some folks, this method will work only if the original list is sorted.
It will not work for a list like [1,1,1,3,2,2,4,3,3,4,4,4,4,5,3,2,1]
I need it to work for a unsorted list like this one.
You can use this function:
def f(lst, seq):
for n in range(len(lst)-len(seq)+1):
if lst[n:n+len(seq)] == seq:
return True
return False
print(f([1,1,2,2,3,3,3,4,5,5,6], [3,4,5]))
Output:
True
You can also turn that into a one-liner:
def f(lst, seq):
return any(lst[n:n+len(seq)] == seq for n in range(len(lst)-len(seq)+1))
I worked out a solution to this when the list is unsorted. I am not sure if this is the most elegant, pythonic way -
List L1 is [1,1,1,3,2,2,4,3,3,4,4,4,4,5,3,2,1]
I will have an empty list L2 = [] and add first item of list to it.
Then I will append L2 with item from L1 if previous item is not the same as current item
So L2 eventually should look like [1,3,2,4,3,4,5,3,2,1]
From this list it will be easy to find a sequence 3-4-5.
New code:
l1 = [1,3,2,4,3,4,5,3,2,1]
l_uni = []
for ii, item in enumerate(l1):
if ii==0:
l_uni.append(item)
elif l1[ii] != l1[ii-1]:
l_uni.append(item)
for jj in range(0,len(l_uni)):
try:
if l_uni[jj] == 3:
if l_uni[jj+1] == 4:
if l_uni[jj+2] == 5:
print('found sequence')
break
except IndexError:
print('no sequence')

find all element positions within a list of lists

Given that l = [[1,2,3], [3,4,5],[5,6]], is there a method to return a list that consists of all positions of 3 within l; i.e. return [2,3]. A sample code I wrote is:
def pos_in_lists(seq, elem):
while i < len(seq):
elem_pos = seq[i].index(elem)
return [elem_pos]
When I run this, it only returns 2, which is not the result I want. What is my mistake? Also, is there a more simple way to solve my problem?
Your code only returns a list with one element (return [elem_pos]). You need to have a list variable (result) outside the loop to keep track of the result of previous lists by appending to that list.
def pos_in_lists(seq, elem):
result = []
i = 0
while i < len(seq):
if elem in seq[i]:
elem_pos = seq[i].index(elem)
result.append(elem_pos)
i += 1
return result
Another simpler alternative is to use list comprehension
def pos_in_lists(seq, elem):
return [l.index(elem) for l in seq if elem in l]
You need to increment "i" each loop
"return" forces the loop to exit. That should be outside the loop at the end of the code.
According to my understanding of the problem, Given list l = [[1,2,3], [3,4,5],[5,6]] and if we have to find 3, the output list should be [2,0].
Following mistakes are there in the code provided:
The code is not working as i is not defined in your method before using it.
We need to store positions of all 3 value present in the list, thus we need to have a list in which we store all the positions of 3 that we can find in the list. You have returned the result as soon as you have found one value. Thus, you are getting only 2.
seq[i].index(elem) will throw value error if 3 is not in the list.
Solution
def pos_in_lists(seq, elem):
res = []
for innerList in seq:
if elem in innerList:
res.append(innerList.index(elem))
return res
pos_in_lists(l,3)
Result would be [2,0]
we can use list comprehension as well:
def pos_in_lists(seq, elem):
return [innerList.index(elem) for innerList in seq if elem in innerList]

Removing negatives from an unknown list in Python

Working in Python, how would I write code to remove negatives from an unknown list of integers using for loops and if statements?
def mod_lis (list):
for i in range(len(list)):
if list[i] < 0:
del list[i]
return list
The problem with your code is that you modify your list during your for loop. The result is that you jump over elements this way and get an IndexError soon since your list has been shortened.
You can do this with this list comprehension:
mylist = [val for val in mylist if val>=0]
You can use filter() and a lambda function:
my_list = filter(lambda x : x >= 0, mylist)
It's better to make a copy of the list without selected items, but if you have to modify in place, try this:
def remove_negatives(list):
pos = 0
for item in list:
if item >= 0:
list[pos] = item
pos += 1
del list[pos:]

Categories