Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.80
AnonymC
1173 / 455 / 28
Регистрация: 23.06.2009
Сообщений: 6,340
Завершенные тесты: 1
#1

поменять местами элементы массива при условии - C++

16.11.2010, 22:00. Просмотров 1228. Ответов 7
Метки нет (Все метки)

Ниже представлен мой код,в комментариях написал как работает программа.
Работает правильно-из одного массива записывает в другой все четные цифры,а из первого удаляются(обнуляются) эти числа.

Вложение 49842

На рисунке показано что в массиве нечетных цифр,два числа стоят так как они стояли до калькуляции.
Вот я хочу чтобы все оставшийся цифры записывались в массив рядом.,отсортировались.
то есть на данной картинке хочу чтобы было
[0]=7
[1]=7
[2]=0
...

Вроде понятно выразился..
код
C++
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
void input(int x[],int);
int calc(int nechet[],int chet[],int);
void print(int x[],int);
 
void main()
{
    //Вызывается функция ввода чисел в первый массив,
    //потом содержимое первого массива  выводится на экран
    //после вызывается функция калькуляции 
    //где все четный цифры из первого массива записываются во второй
    //а из первого массива этот элемент обнуляется
    //в конце выводятся на экран оба массива
    srand(time(0));
    const int n=10;
    int m=0;
    int chet[n];
    int nechet[n];
cout<<"INPUT"<<endl;
    input(chet,n);
    cout<<"PRINT"<<endl;
    print(chet,n);
    cout<<"CALC"<<endl;
    m=calc(chet,nechet,n);
    cout<<"PRINT NECHET"<<endl;
    print(chet,n);
    cout<<"PRINT CHET"<<endl;
    print(nechet,m);
 
 
 
}
 
void input(int x[],int n)
{
    for(int i=0; i<n;i++)
        x[i]=rand()%10;
}
 
int calc(int nechet[],int chet[],int n)
{
    int j=0;
    for(int i=0;i<n;i++)
    {
        if(nechet[i]%2==0 && nechet[i]!=0)
        {
            chet[j]=nechet[i];
            nechet[i]=0;
                j++;
        }
    }
    return j;
}
 
void print(int x[],int n)
{
    for(int i=0;i<n;i++)    
            cout<<"array["<<i<<"]="<<x[i]<<endl;
}


И еще вопрос.
в главной функции я после калькуляции функцию вывода вызываю 2 раза,для каждого из массивов,да еще и перед калькуляцией вызываю эту функцию..
Нельзя ли написать условию какую то,чтобы проверяла если это массив четных чисел,то вместо слова array выводило CHET,в противном случает NECHET..Я подумал я пришел к выводу что если попробовать проверить весь массив то до калькуляции в самом начале программы после инпута будет выводить chet nechet chet nechet..
Было бы красиво чтобы после калькуляции та же функция проверяла массив и записывала на экран нужное слово..То есть перед калькуляцией ARRAY а после сначала все NECHET(сортировано как выше описано) а после CHET.
Хотя вполне возможно что функция ранд возвратит только четные числа,тогда первый массив(нечетный)будет выводится после инпута CHET(вместо array).
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.11.2010, 22:00
Здравствуйте! Я подобрал для вас темы с ответами на вопрос поменять местами элементы массива при условии (C++):

Поменять местами первый и последний элементы. Все единичные элементы массива заменить нулями - C++
Люди добрые, помогите плиз с задачками. В массиве Р, размерности 150 150. поменять местами первый и последний элементы; все единичные...

Поменять местами элементы массива - C++
Есть указатель Mas void *Mas; на массив структур вида. struct ST{ int a; int b; int c; int d; }; Нужно написать функцию,...

Поменять местами элементы массива - C++
Поменять местами первый и средний элемент, если количество элементов массива нечетное, и два средних элемента, если размерность массива...

Поменять местами элементы массива - C++
В массиве A из N элементов поменять местами первый элемент с последним, второй - с предпоследним и т.д. #include &lt;iostream&gt; #include...

Поменять местами элементы массива - C++
Дано одномерный массив с четным количеством элементов. Поменять местами первый элемент с последним, второй с предпоследним, и т.д. Вывести...

Поменять элементы массива местами - C++
Дан массив, элементы которого равны либо единице, либо двойке. Напишите программу, которая расставит элементы массива таким образом, чтобы...

7
AnonymC
1173 / 455 / 28
Регистрация: 23.06.2009
Сообщений: 6,340
Завершенные тесты: 1
16.11.2010, 22:01  [ТС] #2
поменять местами элементы массива при условии
0
accept
4823 / 3244 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
16.11.2010, 22:19 #3
C++
1
cout<<"array["
C++
1
cout << (x[i] % 2 == 0) ? "CHET" : "NECHET") << "["
вообще у тебя функция общего вида и вносить такие изменения - делать её специфичной (мало где применимой)
0
AnonymC
1173 / 455 / 28
Регистрация: 23.06.2009
Сообщений: 6,340
Завершенные тесты: 1
16.11.2010, 23:07  [ТС] #4
Цитата Сообщение от accept Посмотреть сообщение
cout << (x[i] % 2 == 0) ? "CHET" : "NECHET") << "["
если я это запишу перед калькуляций будет CHET или NECHET..перед калькуляций надо array а после уже по массивам..
хотя это просто мне интересно..не задали...точнее то что надо было делать я уже сделал...это прсто интересно
0
accept
4823 / 3244 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
16.11.2010, 23:16 #5
а, ну да
можно ещё передавать в функцию
C++
1
void print(int x[], int n, const char *pref = "array");
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <iostream>
 
using namespace std;
 
void print(int x[], int n, const char *prefix = "array");
 
int main(void)
{
    int n[10] = { 1, 2, 3 };
    
    print(n, 10);
    print(n, 10, "nechet");
    
    return 0;
}
 
void print(int x[], int n, const char *prefix)
{
    for(int i = 0; i < n; i++)
        cout << prefix << "[" << i << "]=" << x[i] << endl;
}
Код
[guest@localhost tests]$ g++ -Wall t.cpp -o t
[guest@localhost tests]$ ./t
array[0]=1
array[1]=2
array[2]=3
array[3]=0
array[4]=0
array[5]=0
array[6]=0
array[7]=0
array[8]=0
array[9]=0
nechet[0]=1
nechet[1]=2
nechet[2]=3
nechet[3]=0
nechet[4]=0
nechet[5]=0
nechet[6]=0
nechet[7]=0
nechet[8]=0
nechet[9]=0
[guest@localhost tests]$
1
AnonymC
1173 / 455 / 28
Регистрация: 23.06.2009
Сообщений: 6,340
Завершенные тесты: 1
16.11.2010, 23:18  [ТС] #6
accept, а как на счет сортировки?

Добавлено через 19 секунд
что бы вместо
0
0
7
0
0
7


было
7
7
0
0
0
0
0
accept
4823 / 3244 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
16.11.2010, 23:39 #7
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
/* пузырьковая сортировка */
void sort(int arr[], size_t n)
{    
    size_t i, j;
    
    for (i = 0; i < n - 1; i++)
        for (j = i + 1; j < n; j++)
            if (arr[i] > arr[j]) {
                int tmp = arr[i];
                arr[i] = arr[j];
                arr[j] = tmp;
            }
}
1
AnonymC
1173 / 455 / 28
Регистрация: 23.06.2009
Сообщений: 6,340
Завершенные тесты: 1
17.11.2010, 14:43  [ТС] #8
accept, да точно,забыл
0
17.11.2010, 14:43
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
17.11.2010, 14:43
Привет! Вот еще темы с ответами:

Поменять местами элементы массива - C++
в двух кваратних матрицах видилено четыре сектора , ограниченные диагоналями : верхний, нижний , левый и правый . Поменять местами элементы...

Поменять местами элементы массива - C++
Здравствуйте! В задании сказано создать динамический массив, в который пользователь сам задает числа и вывести 2-ой динамический массив без...

Поменять местами элементы массива - C++
Есть задача:Найти макс. элемент одномерного массива, минимальный и поменять местами максимальный и минимальный элемент одномерного массива....

Поменять местами элементы массива - C++
2).Сортировка выбором предполагает использование трёх приёмов. Второй - перестановка двух данных элементов местами. Поменяйте местами...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru