Why will this program not run if the variables are not global?


Posted on 16th Feb 2014 07:03 pm by admin

Hey guys I have a kind of perplexing situation that is probably simple, but I can't seem to understand something. I have this code here that is basically a program that solves all 92 eight queens solutions, but prints it out in a 1D array of 8 numbers like an odometer. Each number tells you how many boxes down to go to put a queen inside (You go down the required number of boxes and then put a queen in the next one. EX: 47302516 - you put a queen in boxes 5,8,4,1,3,6,2,7 if you want to think about it from a non-programmer's perspective instead of starting from 0 because of the array going from 0 - 7). Now this program works perfectly fine, but I want to know why I have to declare the "int q[8]; int c;" variables as global for it to work. If I don't, the program just prints out nonsense.

Here is the working program:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
#include #include using namespace std; //All the necessary functions void nextRow(int[],int); void backtrack(int[],int); void print(int[],int); bool ok(int[],int); int q[8]; int c; int main() { //This is the counter to effectively progress through the loop. the "flag" of the program. int counter; c = 0; q[0] = 0; counter = 2; while(c > -1) { c++; counter--; if(c == 8){ print(q,c); counter++; } if(counter == 1){ q[c] = -1; nextRow(q,c); } } return 0; } //This increments the row of the current column you are on, and if the row is equal to 8, it knows to backtrack and try the next row in the previous column. void nextRow(int q[],int c) { q[c]++; if(q[c] == 8) backtrack(q,c); ok(q,c); } //This is the test to see whether or not you can put a queen in that position. bool ok(int q[],int c) { for(int i = 0; i < c; i++) { if(q[c] == q[i] || abs(q[c] - q[i]) == abs(c - i)) nextRow(q,c); } } //Sets the current row equal to zero and goes back to the previous column to increment the row. void backtrack(int q[],int c) { q[c] = 0; c--; if(c == -1) exit(0); nextRow(q,c); } //Goes to the print function when c = 8. void print(int q[],int c) { for(int i = 0; i < 8; i++) { cout << q[i]; } cout << endl; backtrack(q,c); }

And here is the program that prints out nonsense:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
#include #include using namespace std; //All the necessary functions void nextRow(int[],int); void backtrack(int[],int); void print(int[],int); bool ok(int[],int); int main() { //This is the counter to effectively progress through the loop. the "flag" of the program. int counter; int q[8]; int c; c = 0; q[0] = 0; counter = 2; while(c > -1) { c++; counter--; if(c == 8){ print(q,c); counter++; } if(counter == 1){ q[c] = -1; nextRow(q,c); } } return 0; } //This increments the row of the current column you are on, and if the row is equal to 8, it knows to backtrack and try the next row in the previous column. void nextRow(int q[],int c) { q[c]++; if(q[c] == 8) backtrack(q,c); ok(q,c); } //This is the test to see whether or not you can put a queen in that position. bool ok(int q[],int c) { for(int i = 0; i < c; i++) { if(q[c] == q[i] || abs(q[c] - q[i]) == abs(c - i)) nextRow(q,c); } } //Sets the current row equal to zero and goes back to the previous column to increment the row. void backtrack(int q[],int c) { q[c] = 0; c--; if(c == -1) exit(0); nextRow(q,c); } //Goes to the print function when c = 8. void print(int q[],int c) { for(int i = 0; i < 8; i++) { cout << q[i]; } cout << endl; backtrack(q,c); }

Any insight into this would be greatly appreciated for this aspiring C++ programmer :]. I want to know what I would have to change for it to work if the variables weren't global. I know it has to be something with the way I'm passing the variables through the functions, but I'm not sure. Thanks again guys.

No comments posted yet

Your Answer:

Login to answer
58 Like 29 Dislike
Previous forums Next forums
Other forums

Need help with unexpected T-STRING error
I'm a newbie and I'm still learning PHP. However this error has me stumped. I've googled, searched t

Unifying logins of two different scripts
I have two different game scripts which I want to embed on my own site. The problem is I don't want

UDP server recvfrom() always returns -1? :(
Hello all,
I am getting a very strange error in my code :( I am writing a server application in C

Generating unique numbers using php
Hi,
I need help in generating unique number using php.I tired using rand() in php.But, by using r

quick question
Hi ..

i have a question
how do i set a var so it displays via an echo
Code: $logo = '&a

error help - Dynamic Image
I've been working on making my site less cluttered in the directories and more secure lately. In an

Line break?
Hi, I'm new to the forum and new to php. I'm not sure if I'm using the correct terminology so here i

Fetching array then reversing it
Hi, I have a simple problem, I'll try to explain it as best I can:
News entries in my database ar

Downloading file (Headers)
I'm trying to make users download a file, but they must wait 60 seconds before it begins.

But

HeaderSelectedCssClass not working
I have an accordian where I have a drop down list in the first pane and a grid in the second pane.

Sign up to write
Sign up now if you have flare of writing..
Login   |   Register
Follow Us
Indyaspeak @ Facebook Indyaspeak @ Twitter Indyaspeak @ Pinterest RSS



Play Free Quiz and Win Cash