Loop display error

I'm having some issue with my code and with using system("CLS") and system("PAUSE"). Can someone point out how i can fix this issue?

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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
#include <iostream>
#include <fstream>
#include <cstdlib>
#include <conio.h>

using namespace std;
const int MAX=10;

void display_menu();
void active_numbers(int active_number, int array_numbers[], int current_used_numbers);
bool is_list_empty(int active_number);
void numbers_in_text(const int array_numbers[], int active_number, int current_used_numbers);
void input_key(int answer, int & num1, int & num2);
void sort_array(int array_numbers[], int & current_used_numbers, int & active_number);
void ending_of_cases(const int array_numbers[], int active_number, int current_used_numbers);
void write_file(ofstream & output_file, const int array_numbers[], int active_number, int current_used_numbers);
void swap_values(int & v1, int & v2);
void deletetion(int array_numbers[], int & current_used_numbers, int & active_number);
bool is_shift_left_valid(int active_number);
bool is_shift_right_valid(int active_number, int current_used_numbers);
int shift_right(int & active_number);
int shift_left(int & active_number);
void move_right(int array_numbers[], int & active_number);
void move_left(int array_numbers[], int & active_number);


int main()
{
    int array_numbers[MAX], current_used_numbers, active_number;
    ifstream test_file_input("test.txt");

    if(test_file_input.fail())
    {
        cout << "File opening failed. Please make sure the file name is test.txt (input)\n";
        exit(1);
    }

    int next;
    test_file_input >> current_used_numbers >> active_number;
    for(int i=0; i<current_used_numbers; i++)
    {
        test_file_input >> next;
        array_numbers[i]=next;
    }
    test_file_input.close();

    display_menu();
    numbers_in_text(array_numbers, active_number, current_used_numbers);
    int answer=getch(), num1, num2;
    do
    {
        input_key(answer, num1, num2);
        switch(num1)
        {
            case 49://1 Button-Insert

                break;
            case 224://Arrows/Delete/Insert Keys
                switch(num2)
                {
                    case 83://Insert Key-Insert

                        break;
                    case 82://Delete Key-Delete
                        if(current_used_numbers != 0)
                            deletetion(array_numbers, current_used_numbers, active_number);

                        break;
                    case 77://Right Arrow-Move Right
                        if(is_shift_right_valid(active_number, current_used_numbers) == true)
                            move_right(array_numbers, active_number);
                        break;
                    case 75://Left Arrow-Move Left
                        if(is_shift_left_valid(active_number)==true)
                            move_left(array_numbers, active_number);
                        break;
                    case 80://Down Arrow-Select

                        break;
                }
            case 50://2 Button-Delete
                if(current_used_numbers != 0)
                        deletetion(array_numbers, current_used_numbers, active_number);
                break;
            case 51://#3 Button-Sort
                sort_array(array_numbers, current_used_numbers, active_number);
                break;
            case 52://#4 Button-Select

                break;
            case 53://#5 Button-Move Right
                if(is_shift_right_valid(active_number, current_used_numbers) == true)
                    move_right(array_numbers, active_number);
                break;
            case 54://#6 Button-Move Left
                if(is_shift_left_valid(active_number)==true)
                    move_left(array_numbers, active_number);
                break;
            case 55://#7 Button-Exit
                break;
            case 0://F1 / F2 Buttons
                switch(num2)
                {
                    case 59://F1 Button-Exit

                        break;
                    case 60://F2 Button-Sort
                        sort_array(array_numbers, current_used_numbers, active_number);
                        break;
                }

        }
        ending_of_cases(array_numbers, active_number, current_used_numbers);
        system("PAUSE");
    }while(num1 != 0 && num2 != 59 && num1 != 55);
    ofstream output_file("test.txt");
    write_file(output_file, array_numbers, active_number, current_used_numbers);

    return 0;
}

//select next
//insert item
//swap values get index of lowest
//check selection
//array full
//last item selected

//first item selected
//move right/left valid

void insert_item(int array_number[],int & active_number, int & current_used_numbers)
{
    int number;
        cin >> number;
}
void write_file(ofstream & output_file, const int array_numbers[], int active_number, int current_used_numbers)
{
    output_file << current_used_numbers << endl << active_number << endl;

    for(int i =0; i<current_used_numbers; i++)
    {
        output_file << array_numbers[i] << ' ';
    }
    output_file.close();
}

void ending_of_cases(const int array_numbers[], int active_number, int current_used_numbers)
{
    system("CLS");
    display_menu();
    numbers_in_text(array_numbers, active_number, current_used_numbers);
}

void input_key(int answer, int & num1, int & num2)
{
    answer;
    num1=answer;
    if(answer==224 || answer == 0)
    {
        answer=getch();
        num2=answer;
    }
}

void display_menu()
{
    cout << "1.Insert     \"Insert\" key\n"
         << "2.Delete     \"Delete\" key\n"
         << "3.Sort       \"F2\" key\n"
         << "4.Select     \"Down Arrow\" key\n"
         << "5.Move Right \"Right Arrow\" key\n"
         << "6.Move Left  \"Left Arrow\" key\n"
         << "7.Exit       \"F1\" key\n\n";
}

void numbers_in_text(const int array_numbers[], int active_number, int current_used_numbers)
{
    for(int i=0; i<current_used_numbers; i++)
    {
        if(array_numbers[i] == array_numbers[active_number])
            cout << '[' << array_numbers[i] << ']';
        else
            cout << array_numbers[i] << ' ';
    }
}

bool is_shift_left_valid(int active_number)
{
    bool status;
    if(active_number == 0)
       return status =false;
    else
        return status = true;
}

bool is_shift_right_valid(int active_number, int current_used_numbers)
{
    bool status=true;
    if(active_number == current_used_numbers)
        return status = false;
    else
        return status;
}
bool is_list_empty(int active_number)
{
    bool status = true;
    if(active_number==0)
        return status;
    else
        return status=false;
}

void swap_values(int & v1, int & v2)
{
    int temp;
    temp = v1;
    v1 = v2;
    v2 = temp;
}

void sort_array(int array_numbers[], int & current_used_numbers, int & active_number)
{
    int i,j;
    int active_temp = array_numbers[active_number];

    for(i = 0; i<=current_used_numbers;i++)
    {
        for(j = i+1;j<=current_used_numbers;j++)
        {
            int temp;
            if(array_numbers[i] > array_numbers[j])
            {
                temp=array_numbers[i];
                array_numbers[i]=array_numbers[j];
                array_numbers[j]=temp;
            }
        }
    }
    for(i=0; i < current_used_numbers; i++)
    {
        if(active_number == array_numbers[i])
        {
            active_number = i;
        }
    }
}

void deletetion(int array_numbers[], int & current_used_numbers, int & active_number)
{
    for(int i=0; i < current_used_numbers; i++)
    {

        if(array_numbers[i] == active_number)
        {
            for(int j=0; j < current_used_numbers; j++)
            {
                array_numbers[j]=array_numbers[i];
            }
        }
    }
    current_used_numbers--;
}

void move_left(int array_numbers[], int & active_number)
{
    int temp, v1;

    temp=array_numbers[active_number];

    active_number--;

    v1 =array_numbers[active_number];

    active_number++;
    array_numbers[active_number]=v1;
    active_number--;
    array_numbers[active_number]=temp;
}
void move_right(int array_numbers[], int & active_number)
{
    int temp, v1;

    temp=array_numbers[active_number];

    active_number++;

    v1 =array_numbers[active_number];

    active_number--;
    array_numbers[active_number]=v1;
    active_number++;
    array_numbers[active_number]=temp;

}
int shift_left(int & active_number)
{
    active_number--;
    return active_number;
}

int shift_right(int & active_number)
{
    active_number++;
    return active_number;
}

Last edited on
The loop starts at 50 and ends at 155.

And the files formatting loops like
#<-current amount of numbers
# <- active subscript
# # # # <--- numbers
Topic archived. No new replies allowed.