Форум программистов, компьютерный форум, киберфорум
Наши страницы
C для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
LuckyMaster
0 / 0 / 0
Регистрация: 10.10.2014
Сообщений: 4
1

Сформировать массив, который будет состоять из чисел, входящих как в массив A, так и в массив B

10.10.2014, 07:05. Просмотров 1198. Ответов 3
Метки нет (Все метки)

Задание: На основе исходных массивов A[n] и B[m] (n и m – рабочие размеры массивов) сформировать массив C, который будет состоять из чисел, которые одновременно входят как в массив A, так и в массив B. Упорядочить массив С по возрастанию, используя метод выбора. Вывести элементы массива С на экран.
Массивы A, B и C являются целочисленными. Значения m и n, а также значения элементов массива A и B вводятся с клавиатуры.
Проблема: Компилятор не выдает ошибку, однако после ввода первого числа первого массива Windows прекращает работу программы и предлагает отладку. Любые конструктивные замечания приветствуются. (компилятор VS 2012)

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
#include "stdafx.h"
#include "stdio.h"
#include "stdlib.h"
#include "conio.h"
 
 
int _tmain(int argc, _TCHAR* argv[])
{
    int *A, *B, *C, i,j,m,n,k=0,imin,min;
    printf("Input n=");
    scanf_s("%d",&n);
    printf("Input m=");
    scanf_s("%d",&m);
    do {
        A=(int*)malloc(n*sizeof(int));
        B=(int*)malloc(m*sizeof(int));
        if (n>=m) C=(int*)malloc(n*sizeof(int));
        else C=(int*)malloc(m*sizeof(int));
        }
    while ((A=0)||(B=0)||(C=0));
    for(i=0; i<n; i++) {
        printf("A[%d]=",i);
        scanf_s("%d",&*(A+i));
        }
    for(j=0; j<m; j++) {
        printf("B[%d]=",j);
        scanf_s("%d",&*(B+j));
        }
    for(i=0; i<n; i++)
        printf("A[%d]=%d\n",i,*(A+i));
    for(i=0; i<m; i++)
        printf("B[%d]=%d\n",i,*(B+i));
    for(i=0; i<n; i++)
        for(j=0; i<m; j++) {
            if (*(A+i)==*(B+j)) {           
                *(C+k)=*(A+i);
                printf("C[%d]=%d",k,*(C+k));
                k++;
                }
        }
    for(i=0; i<k; i++) {
        min=*(A+i); imin=i;
        for(j=i+i; j<k; j++)
            if (*(A+j)<min) {
                min=*(A+i); imin=j; 
                }
        *(A+imin)=*(A+i);
        *(A+i)=min;
        }
    for(i=0; i<k; i++)
        printf("C[%d]=%d",i,*(C+i)); 
    free(A);
    free(B);
    free(C);
    return 0;
}
0
QA
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
10.10.2014, 07:05
Ответы с готовыми решениями:

Сформировать массив C, который будет состоять из чисел, которые одновременно входят как в массив A, так и в массив B
Есть задание :На основе исходных массивов A и B (n и m – рабочие размеры массивов) сформировать...

Построить массив d из элементов, которые входят как в массив a так и в массив b
Дан массив a и b состоящий из n элементов. Построить массив d из элементов, которые входят как в...

Дан массив X(25). Сформировать новый массив из чисел исходного, лежащих в интервале [-3,7]
Доброго времени суток... Написание данной программы на языке (С) вызвало у меня некое...

Дан массив D(12). Сформировать новый массив из положительных кратных 3 чисел исходного
D(12) для более лёгкой проверки я сделал massiv. Я не знаю почему первым в massiv1 идёт 0 и не...

Массив: Сформировать и вывести массив размера N, содержащий N первых положительных нечетных чисел: 1, 3, 5
Дано целое число N ( &gt; 0). Сформировать и вывести целочисленный массив размера N, содержащий N...

3
ПерС
432 / 357 / 322
Регистрация: 05.11.2013
Сообщений: 1,012
Записей в блоге: 6
Завершенные тесты: 1
10.10.2014, 08:49 2
занулять не нада
видимо, предполагалось
C++
1
while ((A==0)||(B==0)||(C==0));
в строке 20
хотя тоже неясно зачем...

еще обрати внимание на границы циклов в 33-34
C++
1
2
    for(i=0; i<n; i++)
        for(j=i; j<m; j++) {
предполагалось?
1
zss
Модератор
Эксперт С++
8729 / 7641 / 4724
Регистрация: 18.12.2011
Сообщений: 20,326
Завершенные тесты: 1
10.10.2014, 11:00 3
C++
1
2
3
4
5
6
7
8
A=(int*)malloc(n*sizeof(int));
B=(int*)malloc(m*sizeof(int));
C=(int*)malloc(max(n,m)*sizeof(int));
if(A==NULL || B==NULL || C==NULL)
{
    printf("Ошибка выдедения памяти");
    return 1;
}
1
LuckyMaster
0 / 0 / 0
Регистрация: 10.10.2014
Сообщений: 4
02.11.2014, 17:32  [ТС] 4
Кому интересно вот полностью работающий вариант программы:
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
#include "stdafx.h"
#include "stdio.h"
#include "stdlib.h"
#include "conio.h"
 
 
int _tmain(int argc, _TCHAR* argv[])
{
    int *A, *B, *C, i,j,m,n,k=0,imin,min;
    printf("Input n=");
    scanf_s("%d",&n);
    printf("Input m=");
    scanf_s("%d",&m);
    A=(int*)malloc(n*sizeof(int));
    B=(int*)malloc(m*sizeof(int));
    if (n>=m) C=(int*)malloc(n*sizeof(int));
    else C=(int*)malloc(m*sizeof(int));
    if(A==NULL || B==NULL || C==NULL) {
        printf("Memory allocation error.");
        return 1;
        }
    for(i=0; i<n; i++) {
        printf("A[%d]=",i);
        scanf_s("%d",&*(A+i));
        }
    for(j=0; j<m; j++) {
        printf("B[%d]=",j);
        scanf_s("%d",&*(B+j));
        }
    for(i=0; i<n; i++)
        for(j=0; j<m; j++) {
            if (*(A+i)==*(B+j)) {           
                *(C+k)=*(A+i);
                printf("C[%d]=%d; ",k,*(C+k));
                k++;
                }
        }
    for(i=0; i<k; i++) {
        min=*(C+i); imin=i;
        for(j=i+1; j<k; j++)
            if (*(C+j)<min) {
                min=*(C+j); imin=j; 
                }
        *(C+imin)=*(C+i);
        *(C+i)=min;
        }
    printf("\n");
    for(i=0; i<k; i++)
        printf("C[%d]=%d; ",i,*(C+i)); 
    printf("\n");
    free(A);
    free(B);
    free(C);
    return 0;
}
0
02.11.2014, 17:32
Answers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
02.11.2014, 17:32

Создать массив, который будет состоять только из неповторяющихся чисел заданного массива
Задан массив чисел. Создать другой массив, который будет состоять только из неповторяющихся чисел...

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

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


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

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

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