Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 20.11.2015
Сообщений: 4

Сравнение массивов

28.11.2015, 16:50. Показов 1197. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!
Не удается сравнить два массива q и с. Алгоритм шифрует по алгоритму CRC и необходимо расшифровать сообщение, но при сравнении массивов выдается одно и тоже сообщение что посылка удачно расшифрована.
Помогите пожалуйста.

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
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
#define _CRT_SECURE_NO_WARNINGS
#include< stdio.h>
#include< conio.h>
 
 
void main()
{
    int i, j, n, g, a, arr[20], gen[20], b[20], q[20], x[20],c[20], check, s;
    check = 0;
    printf("\n\t Enter no. of data bits: ");
    scanf("%d", &n);
    printf("\n\t Enter the data to be sent: \n");
    for (i = 0; i<n; i++)
        scanf("%d", &arr[i]);
    printf("\n\t Enter no. of divisor bits: ");
    scanf("%d", &g);
    do
    {
        printf("\n\t Enter the generator data: \n");
        for (j = 0; j<g; j++)
            scanf("%d", &gen[j]);
    } while (gen[0] != 1);
    printf("\n\t The divisor is:");
    for (j = 0; j<g; j++)
        printf("%d", gen[j]);
    a = n + g;
    printf("\n\t The transmitter side data is:");
    for (i = 0; i<j; ++i)
        arr[n + i] = 0;
    for (i = 0; i<a; ++i)
        printf("%d", arr[i]);
    for (i = 0; i<n; ++i)
        q[i] = arr[i];
    for (i = 0; i<n; ++i)
    {
        if (arr[i] == 0)
        {
            for (j = i; j<g + i; ++j)
                arr[j] = arr[j] ^ 0;
        }
        else
        {
            arr[i] = arr[i] ^ gen[0];
            arr[i + 1] = arr[i + 1] ^ gen[1];
            arr[i + 2] = arr[i + 2] ^ gen[2];
            arr[i + 3] = arr[i + 3] ^ gen[3];
        }
    }
    printf("\n\t The CRC is :");
    for (i = n; i<a; ++i)
        printf("%d", arr[i]);
    for (i = 0; i<g - 1; ++i)
        x[i] = arr[i];
    s = n + a;
    for (i = n; i<s; i++)
        q[i] = arr[i];
    printf("\n");
    for (i = 0; i<a; i++)
        printf("%d", q[i]);
    _getch();
    printf("\n\t Enter no. of data bits received: ");
    scanf("%d", &n);
    printf("\n\t Enter the data received: \n");
    for (i = 0; i<n; i++)
        scanf("%d", &arr[i]);
    for (i = n, j = g - 1; i<a, j<0; i++, j--)
        arr[i] = c[j];
    printf("\n\t The receiver side data is:");
    for (i = 0; i<a; ++i)
        printf("%d", arr[i]);
    for (i = 0; i<n; ++i)
        c[i] = arr[i];
    for (i = 0; i<n; ++i)
    {
        if (arr[i] == 0)
        {
            for (j = i; j<g + i; ++j)
                arr[j] = arr[j] ^ 0;
        }
        else
        {
            arr[i] = arr[i] ^ gen[0];
            arr[i + 1] = arr[i + 1] ^ gen[1];
            arr[i + 2] = arr[i + 2] ^ gen[2];
            arr[i + 3] = arr[i + 3] ^ gen[3];
        }
    }
    printf("\n\t The CRC at the receiver is:");
    for (i = n; i<a; ++i)
        printf("%d", arr[i]);
    //s = n + a;
    for (i = n; i<a; i++)
        c[i] = arr[i];
    printf("\n");
    i = 0;
    while (i<a)
    {
        if (c[i] == q[i])
            check = 0;
        else
            check = 1;
        i++;
    }
    printf("\n\n Result of CRC Error detection is: ");
    if (check == 0)
        printf("\n\t Data is accepted successfully!");
    else
        printf("\n Resend the data again!");
    _getch();
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
28.11.2015, 16:50
Ответы с готовыми решениями:

Сравнение массивов: найти максимальное перебором массивов
Добрый вечер такая проблема даны два одномерных массива A, B причем в каждом массиве записанно число по разрядно Задачи найти...

Сравнение 2х массивов в С++
Ребята, помогите пожалуйста написать вот такую прогу: Запросить и считать два массива у пользователя (две последовательности целых чисел...

Сравнение массивов
заданы два массива целых чисел с одинаковой размерности. Сравнить их соответствующие элементы и вывести на экран массив, составленный из...

6
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
28.11.2015, 17:02
Вместе с check = 1 делай break.
0
0 / 0 / 0
Регистрация: 20.11.2015
Сообщений: 4
28.11.2015, 17:23  [ТС]
Попробовал так сделать, осталось все также Либо как то можно посмотреть длину массива, чтобы посмотреть совпадает или нет количество данных?


C++
1
2
3
4
5
6
7
8
9
    while (i<s)
    {
        if (c[i] == q[i])
            check = 0;
        else
            check = 1;
                i++;
        break;
    }
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
28.11.2015, 18:02
Лучший ответ Сообщение было отмечено MakaronSki как решение

Решение

C++
1
check = memcmp(c, q, a);
1
0 / 0 / 0
Регистрация: 20.11.2015
Сообщений: 4
28.11.2015, 18:17  [ТС]
Попробовал так, все равно не помогло.

Добавлено через 8 минут
Получилось! Спасибо огромное!
0
518 / 410 / 188
Регистрация: 08.04.2013
Сообщений: 1,750
28.11.2015, 18:35
Лучший ответ Сообщение было отмечено MakaronSki как решение

Решение

помощь просит напрячь можно, а людям рассказать как сделал - лень, если программистом назвался доведи тему до логического конца,если не жлоб
1
0 / 0 / 0
Регистрация: 20.11.2015
Сообщений: 4
28.11.2015, 19:02  [ТС]
C++
1
2
3
4
5
6
7
8
 while (i<a)
    {
        if (c[i] == q[i])
            check = 0;
        else
            check = 1;
        i++;
    }
Заменил данный цикл на функцию memcmp с присваиванием к переменной check, как подсказал nmcf,
и на всякий случай дополнительно вывел эти массивы, чтобы сравнить их, в принципе все что необходимо было исправить

C++
1
2
3
4
5
6
7
8
9
10
11
12
check = memcmp(c, q, a);
    printf("\n\n Result of CRC Error detection is: ");
    if (check == 0)
        printf("\n\t Data is accepted successfully!");
    else
        printf("\n Resend the data again!");
    printf("\n");
    for (i = 0; i<a; i++)
    printf("%d", q[i]);
    printf("\n");
    for (i = 0; i<a; i++)
        printf("%d", c[i]);
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
28.11.2015, 19:02
Помогаю со студенческими работами здесь

Сравнение массивов
Здраствуйте, как можно сравнить два элемента buffer и asd? Вот код: char* buffer = new char ; char sas =...

Сравнение массивов
нужно сравнить весь массив из 6 элементов ,,кроме последнего,равны ли элементы массива 0 и вывести на экран равны ,или нет.

Сравнение массивов
После заполнения динамического массива числами,в моем случае 1 и 0,компилятор не производит действий,останавливает работу.Спасибо#include...

Сравнение двух массивов
даны два массива целых чисел одинакового размера. сравнить элементы двух массивов и сохранить результаты в третий массив в соответствующей...

Сравнение числовых массивов
Есть два числовых массива в одном 4 элемента в другом 5 (то есть разное количество) Как с помощью C++ можно сравнить эти массивы Нужно...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru