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

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

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 9, средняя оценка - 4.67
MermaidAlyona
Сообщений: n/a
#1

Задачка про массивы - C++

29.10.2008, 20:04. Просмотров 1083. Ответов 2
Метки нет (Все метки)

Только начала изучать программирование, пытаюсь разбиратся ,но не всё так просто , помогите пжлст решить задачку на массивы

Даны два массива размера N, элементы которых упорядоченны по возростанию объединить эти массивы так, чтобы результирующий массив остался упорядоченным.

Желательно с коментариями ,я хочу понять как она решается.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
29.10.2008, 20:04     Задачка про массивы
Посмотрите здесь:

Задачка про двумерные массивы - C++
Задача о замочной скважине, подойдет ли ключ к замку. Даны мозаичные изображения замочной скважины и ключ. Нужно узнать, пройдёт ли ключ в...

Задачка про треугольник. - C++
Для вас эта задача очень легкая, но я не как не могу ее сделать. Пожалуйста помогите! Условие такое : В треугольнике (см. рис. 1.8,...

Задачка про строки и слова - C++
Ошибочка закралась: суть задачки надо прочитать файл и вывести слова которые начинаются и кончаются на "a" (ну вот вбил я в свой файл для...

Олимпиадная задачка про Роботов - C++
Помогите решить не могу додуматься Роботы Кафедра ТМОИ создает роботов, которые могут находить и собирать мины с полей. Прежде чем...

Задачка про Барона Мюнхгаузена - C++
Барон Мюнхаузен, выйдя на экологически чистую охоту, зарядил свое ружье косточками вишен. После того как он удачно попал между рога оленям,...

Задачка про деревья на рекурсию - C++
Пасаны, не особо шарю деревья, а еще нужно рекурсия.. Короче нужна помощь, хотя бы объеснить что как должно работать, буду очень...

Простая задачка про тернарный оператор - C++
Переписал с учебника простую задачку, однако на 10 и 12 строке показывает ошибки. Что тут не так? #include<iostream> #include<cmath> ...

Задачка - крепкий орешек про линейку - C++
Никак не могу разобраться с задачкой. Скажу сразу, что она хоть и для новичков - программистов, но считается сложной, олимпиадной.Даже не...

олимпиадная задачка про брак на заводе - C++
Уважаемые программисты, вот еще одна задачка из серии олимпиадных. Может, она не такая сложная, но мне, как новичку в программировании,...

Задачка про стол. Размещение гостей без повторений - C++
Представьте, что вы собираетесь пригласить к себе шестерых гостей, но за вашим столом могут разместиться всего лишь 4 человека Сколькими...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Prividenie
74 / 74 / 6
Регистрация: 05.10.2008
Сообщений: 233
30.10.2008, 03:02     Задачка про массивы #2

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
#include <stdio.h>
#define N 5
int main()
{
int a[N]={2,7,8,9,10},b[N]={1,3,4,5,6},c[N*2],i,j,kol=0,temp;
for(i=0;i<N*2;i++)//сложить оба массива в массив c
{
    if(i<N)
        c[i]=a[i];
    if(i>=N)
        c[i]=b[i-N];
    printf("%d ",c[i]);
}
for(i=0;i<N*2-1;i++)//отсортировать
{
    for(j=kol+1;j<N*2;j++)
    {
        if(c[i]>c[j])
        {
            temp=c[i];
            c[i]=c[j];
            c[j]=temp;
        }
    }
kol++;
}
printf("\n");
for(i=0;i<N*2;i++)
    printf("%d ",c[i]);
printf("\n");
return 0;
}
Inlight
43 / 42 / 2
Регистрация: 17.09.2008
Сообщений: 98
30.10.2008, 11:41     Задачка про массивы #3
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
#include <conio.h> // _getch
#include <iostream> // cout
 
using namespace std;
 
#define N 5
 
int main()
{
    int a[N]={2,7,8,9,10};
    int b[N]={1,3,4,5,6};
    int c[N*2];
    int iA = 0;
    int iB = 0;
    int iC = 0;
    // Сравниваем элементы массивов, на которые указывают счётчики iA и iB,
    // между собой, меньший заносим в массив с,
    // счётчик массива с меньшим элементом устанавливаем на следующий за ним.
    // Делаем так, пока не "исчерпаем" один из массивов.
    // (его счётчик будет больше "размер массива-1", массивы-то с 0 начинаются)
    while ((iA < N) && (iB < N)) {
        if (a[iA] < b[iB]) {
            c[iC] = a[iA];
            iA++;
            iC++;
        }
        else {
            c[iC] = b[iB];
            iB++;
            iC++;
        }
    }
    // Один из массивов ещё не "исчерпан", находим его и заносим его элементы
    // в массив с (т.к. они всё-равно уже отсортированы)
    while (iA < N) {
        c[iC] = a[iA];
        iA++;
        iC++;
    }
    while (iB < N) {
        c[iC] = b[iB];
        iB++;
        iC++;
    }
    // выводим результат на экран
    for (int iC = 0; iC<N*2; iC++) {
        cout << c[iC] << " ";
    }
    // заглушка, чтобы увидеть результаты
    _getch();
    return 0;
}
Yandex
Объявления
30.10.2008, 11:41     Задачка про массивы
Ответ Создать тему
Опции темы

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