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

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

Войти
Регистрация
Восстановить пароль
 
 
Voland28RUS
3 / 3 / 0
Регистрация: 26.02.2014
Сообщений: 24
#1

Отсортировать массив таким образом, чтобы все нули находились в начале, а единицы — в конце массива - C++

07.03.2014, 16:15. Просмотров 1004. Ответов 21
Метки нет (Все метки)

Здравствуйте, дано такое задание Элементами массива IM(N) являются числа 0 и 1. Отсортировать этот массив таким образом, чтобы все нули находились в начале, а единицы - в конце массива. Дополнительный массив не заводить. У меня получился такой код
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
59
60
61
62
63
64
65
66
67
68
69
// ConsoleApplication3.cpp: определяет точку входа для консольного приложения.
//
 
#include "stdafx.h"
#include "locale.h"
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
const int MaxSize = 79; //Максимальная размерность массива
 
int input(void);
void fill(int*,int);
void show(int*,int);
void exchange(int*,int*);
 
int main(void){
    setlocale(LC_ALL, "Russian");
    int N;
    int* IM;    //Объявление указателя на массив
    printf("Элементами массива IM размерностью от 1 до %i значений являются числа 0 и 1."\
           "\nСортировка массива по возрастанию пузырьковым методом.\n\n",MaxSize);
    do {
        do {
            printf("\nВведите размерность массива: ");
            N=input();
            if (N<=MaxSize && N>0){
                IM=(int*)malloc(sizeof(int)*N); //Выделение памяти под массив
                fill(IM,N);
                show(IM,N);
                putchar('\n');
                for (int i=N-1;i>0;i--){    //Двойной обход массива с сортировкой
                    for (int j=0;j<i;j++) exchange(&IM[j],&IM[j+1]);
                    show(IM,N);     //Вывод промежуточного состояния массива
                    putchar('\n');}
                free (IM);
                break;
            } else printf("^Размерность массива - число 1-%i",MaxSize);
        } while (1);
        printf("\nНажмите любую клавишу чтобы продолжить, [N] чтобы выйти...");
    } while (_getch()!=0x6E);
}
 
int input(void){
    char str[256];
    scanf_s("%s",&str);
    return atoi(str);}
 
void fill(int* dst,int size){
    for (int i=0;i<size;i++){   //Заполнение всех элементов массива
        do{         //элементами 0 или 1 с клавиатуры
            printf("IM[%i]:",i);
            dst[i]=input();
        } while ((dst[i]!=0)&&(dst[i]!=1)); //Повтор ввода если введено неверно
    }
}
 
void show(int* IM,int size){
    for (int i=0;i<size;i++) printf("%i",IM[i]);}
 
void exchange(int* first,int* second){
    int temp;
    if (*second<*first){
        temp=*first;
        *first=*second;
        *second=temp;
    }
 
 
}
Программа запускается, но при вводе размерности массива выскакивает ошибка Необработанное исключение по адресу 0x778DF6A4 (msvcr110d.dll) в ConsoleApplication3.exe: 0xC0000005: нарушение прав доступа при записи по адресу 0x00AA0000.
Подскажите пожалуйста где ошибка.
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.03.2014, 16:15
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Отсортировать массив таким образом, чтобы все нули находились в начале, а единицы — в конце массива (C++):

Отсортировать массив из 0 и 1 так, чтобы все нули находились в начале, а все единицы - в конце массива - C++
Тема: Функции 1. Дано одномерный массив, заполненный 0 и 1 в произвольном порядке. Отсортировать данный массив таким образом, чтобы все...

Отсортировать массив, чтобы все положительные числа находились в начале, отрицательные - в конце - C++
Помогите пожалуйста. Дан вещественный массив A( N ) . Отсортировать его таким образом , чтобы все положительные числа находились в...

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

Отсортировать заданную последовательность так, чтобы все нули оказались в конце - C++
Задача: Дана последовательность чисел, отсортировать эту последовательность так, чтобы все нули оказались в конце, а все остальные числа...

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

Дан вещественный массив А (n). Отсортировать его таким образом, чтобы - C++
Задача 45. Дан вещественный массив А (n). Отсор¬тировать его таким образом, чтобы все положительные числа находились в начале, а...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Voland28RUS
3 / 3 / 0
Регистрация: 26.02.2014
Сообщений: 24
07.03.2014, 18:22  [ТС] #16
за что?
Catstail
Модератор
22538 / 10943 / 1775
Регистрация: 12.02.2012
Сообщений: 18,080
07.03.2014, 18:35 #17
"За информацию, которая мне, как путешественнику, чрезвычайно интересна" (М.Булгаков. "Мастер и Маргарита")

А если серьезно, я не верил, что могут давать такие методически неверные задания. Но пришлось поверить...
Voland28RUS
3 / 3 / 0
Регистрация: 26.02.2014
Сообщений: 24
07.03.2014, 18:40  [ТС] #18
ну что поделать,какое дали( так может быть все-таки укажете на ошибку в изначальном варианте?
и почему в том варианте нужно вводить размерность массива и значения, а в вашем коде просто отсортированный массив сразу.
Catstail
Модератор
22538 / 10943 / 1775
Регистрация: 12.02.2012
Сообщений: 18,080
07.03.2014, 19:48 #19
У меня этот код работает (русские текст убрал):

Enter array size 10
IM[0]:1
IM[1]:1
IM[2]:0
IM[3]:0
IM[4]:1
IM[5]:1
IM[6]:0
IM[7]:0
IM[8]:1
IM[9]:1
1100110011
1001100111
0011001111
0010011111
0000111111
0000111111
0000111111
0000111111
0000111111
0000111111

Press any key (N-Exit)
Voland28RUS
3 / 3 / 0
Регистрация: 26.02.2014
Сообщений: 24
08.03.2014, 10:43  [ТС] #20
Я извиняюсь)а тот код который вы написали только он должен быть или им нужно заменить какую-то часть моего варианта?)
Catstail
Модератор
22538 / 10943 / 1775
Регистрация: 12.02.2012
Сообщений: 18,080
08.03.2014, 12:16 #21
Его нужно встроить в твой вариант
Voland28RUS
3 / 3 / 0
Регистрация: 26.02.2014
Сообщений: 24
08.03.2014, 13:12  [ТС] #22
а куда именно?
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
08.03.2014, 13:12
Привет! Вот еще темы с ответами:

Переставить элементы массива так, чтобы сначала располагались все нули, затем все двойки и, наконец, все единицы - C++
Добрый день ! У меня к вам просьба. Помогите решить задачу по с++ начинающему чайнику. :wall: Задача. В массиве A(N) каждый...

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

Преобразовать массив таким образом, чтобы сначала располагались все по- ложительные элементы, а потом все остальные - C++
#include &lt;iostream&gt; #include &lt;stdlib.h&gt; #include &lt;time.h&gt; #include &lt;cmath&gt; using namespace std; void float1(double...

Преобразовать массив таким образом, чтобы сначала располагаись все положительные элементы, а потом-все отлицательные - C++
Преобразовать массив таким образом, чтобы сначала располагаись все положительные элементы, а потом-все отлицательные (элементы, равные 0,...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
08.03.2014, 13:12
Ответ Создать тему
Опции темы

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