iterating through elements in different index positions
Multi tool use
I am trying to make a program that prints a grid from an integer input.
def grids(units):
natural_number = int(input())
# define size
x = y = units
# create empty rows
grid =
# for each row defined by Y, append a list containing X occurrences of "."
for row in range(y):
grid.append(list("." * x))
# fills the first row with natural_number
for elements in range(units):
grid[0][elements] = natural_number
# fills the first column of each row with natural_number
for elements in range(units):
grid[elements][0] = natural_number
return grid
>>> grids(3)
>? 5
[[5, 5, 5], [5, '.', '.'], [5, '.', '.']]
for the empty positions in grid[1][1], grid[1][2], grid[2][1], and grid[2][2]
My goal is to make the following outputs
''''
grid[1][1] = grid[1][0] + grid[0][1]
grid[1][2] = grid[1][1] + grid[0][2]
grid[2][1] = grid[2][0] + grid[1][1]
grid[2][2] = grid[2][1] + grid[1][2]
grid[i][j] = grid[i][j-1] + grid[i-1][j]
''''
to fill in for those positions, I came up with the following code.
However, the code returns an error: int object is not iterable.
The code also seems to pose the problem where it will not iterate for grid[1][2] or grid[2][1]
for i, j in range(1, units):
grid[i][j] = grid[i][j - 1] + grid[i - 1][j]
return grid
What actions can I take to amend this problem?
python python-3.x python-2.7
add a comment |
I am trying to make a program that prints a grid from an integer input.
def grids(units):
natural_number = int(input())
# define size
x = y = units
# create empty rows
grid =
# for each row defined by Y, append a list containing X occurrences of "."
for row in range(y):
grid.append(list("." * x))
# fills the first row with natural_number
for elements in range(units):
grid[0][elements] = natural_number
# fills the first column of each row with natural_number
for elements in range(units):
grid[elements][0] = natural_number
return grid
>>> grids(3)
>? 5
[[5, 5, 5], [5, '.', '.'], [5, '.', '.']]
for the empty positions in grid[1][1], grid[1][2], grid[2][1], and grid[2][2]
My goal is to make the following outputs
''''
grid[1][1] = grid[1][0] + grid[0][1]
grid[1][2] = grid[1][1] + grid[0][2]
grid[2][1] = grid[2][0] + grid[1][1]
grid[2][2] = grid[2][1] + grid[1][2]
grid[i][j] = grid[i][j-1] + grid[i-1][j]
''''
to fill in for those positions, I came up with the following code.
However, the code returns an error: int object is not iterable.
The code also seems to pose the problem where it will not iterate for grid[1][2] or grid[2][1]
for i, j in range(1, units):
grid[i][j] = grid[i][j - 1] + grid[i - 1][j]
return grid
What actions can I take to amend this problem?
python python-3.x python-2.7
add a comment |
I am trying to make a program that prints a grid from an integer input.
def grids(units):
natural_number = int(input())
# define size
x = y = units
# create empty rows
grid =
# for each row defined by Y, append a list containing X occurrences of "."
for row in range(y):
grid.append(list("." * x))
# fills the first row with natural_number
for elements in range(units):
grid[0][elements] = natural_number
# fills the first column of each row with natural_number
for elements in range(units):
grid[elements][0] = natural_number
return grid
>>> grids(3)
>? 5
[[5, 5, 5], [5, '.', '.'], [5, '.', '.']]
for the empty positions in grid[1][1], grid[1][2], grid[2][1], and grid[2][2]
My goal is to make the following outputs
''''
grid[1][1] = grid[1][0] + grid[0][1]
grid[1][2] = grid[1][1] + grid[0][2]
grid[2][1] = grid[2][0] + grid[1][1]
grid[2][2] = grid[2][1] + grid[1][2]
grid[i][j] = grid[i][j-1] + grid[i-1][j]
''''
to fill in for those positions, I came up with the following code.
However, the code returns an error: int object is not iterable.
The code also seems to pose the problem where it will not iterate for grid[1][2] or grid[2][1]
for i, j in range(1, units):
grid[i][j] = grid[i][j - 1] + grid[i - 1][j]
return grid
What actions can I take to amend this problem?
python python-3.x python-2.7
I am trying to make a program that prints a grid from an integer input.
def grids(units):
natural_number = int(input())
# define size
x = y = units
# create empty rows
grid =
# for each row defined by Y, append a list containing X occurrences of "."
for row in range(y):
grid.append(list("." * x))
# fills the first row with natural_number
for elements in range(units):
grid[0][elements] = natural_number
# fills the first column of each row with natural_number
for elements in range(units):
grid[elements][0] = natural_number
return grid
>>> grids(3)
>? 5
[[5, 5, 5], [5, '.', '.'], [5, '.', '.']]
for the empty positions in grid[1][1], grid[1][2], grid[2][1], and grid[2][2]
My goal is to make the following outputs
''''
grid[1][1] = grid[1][0] + grid[0][1]
grid[1][2] = grid[1][1] + grid[0][2]
grid[2][1] = grid[2][0] + grid[1][1]
grid[2][2] = grid[2][1] + grid[1][2]
grid[i][j] = grid[i][j-1] + grid[i-1][j]
''''
to fill in for those positions, I came up with the following code.
However, the code returns an error: int object is not iterable.
The code also seems to pose the problem where it will not iterate for grid[1][2] or grid[2][1]
for i, j in range(1, units):
grid[i][j] = grid[i][j - 1] + grid[i - 1][j]
return grid
What actions can I take to amend this problem?
python python-3.x python-2.7
python python-3.x python-2.7
asked Nov 14 '18 at 1:08
V AnonV Anon
2066
2066
add a comment |
add a comment |
1 Answer
1
active
oldest
votes
If you take
for i, j in range(1,3):
And replace it with
for i in range(1, 3):
for j in range(1, 3):
I think that will fix your problems
add a comment |
Your Answer
StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");
StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "1"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);
else
createEditor();
);
function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);
);
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53291753%2fiterating-through-elements-in-different-index-positions%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
If you take
for i, j in range(1,3):
And replace it with
for i in range(1, 3):
for j in range(1, 3):
I think that will fix your problems
add a comment |
If you take
for i, j in range(1,3):
And replace it with
for i in range(1, 3):
for j in range(1, 3):
I think that will fix your problems
add a comment |
If you take
for i, j in range(1,3):
And replace it with
for i in range(1, 3):
for j in range(1, 3):
I think that will fix your problems
If you take
for i, j in range(1,3):
And replace it with
for i in range(1, 3):
for j in range(1, 3):
I think that will fix your problems
answered Nov 14 '18 at 1:59
jpmartjpmart
16
16
add a comment |
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53291753%2fiterating-through-elements-in-different-index-positions%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Z,1,5 ISs8tu,uUYE5irS1 p0CvIxgq3ZobVS kLxsxVXt7Nh p Wse8 6MxDuQPEFLyZ5 h