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

Программа поиска в массиве структур, содержащих объединения - C++

Восстановить пароль Регистрация
 
Let_Nov
0 / 0 / 0
Регистрация: 24.02.2014
Сообщений: 4
03.03.2014, 00:16     Программа поиска в массиве структур, содержащих объединения #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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
#include <stdio.h>
#define x 3
union Re
 {
  int re_i;
  float re_f;
 };
union Im
 {
  int im_i;
  float im_f;
 };
struct complex
 {
  union Re p_re;
  union Im p_im;
 } arr[x];
main()
{
 int i=0;
 short kod;
 printf("Тип данных: \n1. - Целочисленный;\n2. - Вещественный.\nВведите код: ");
 scanf("%d", &kod);
 switch (kod)
    {
 case 1: printf("\nRe + i*Im\n---------");
     while (i<x)
    {
     printf("\nВведите комплексное число #%d\nRe = ", i+1);
     scanf("%d", &arr[i].p_re.re_i);
     printf("Im = ");
     scanf("%d", &arr[i].p_im.im_i);
     printf("Введенное комплексное число: %d + i*%d\n---------", arr[i].p_re.re_i, arr[i].p_im.im_i);
         i++;
    }
     int search_i_re, search_i_im;
         short search_kod_i;
     printf("\nПоиск по:\n1. - Номеру записи;\n2. - Значению Re и Im.\nВведите код: ");
     scanf("%d", &search_kod_i);
     switch (search_kod_i)
        {
        case 1: printf("Введите номер записи: ");
            scanf("%d", &i);
            printf("Результат поиска: %d + i*%d", arr[i-1].p_re.re_i, arr[i-1].p_im.im_i);
                        break;
        case 2: int search_re_i, search_im_i;
            printf("Введите Re: ");
            scanf("%d", &search_re_i);
            printf("Введите Im: ");
            scanf("%d", &search_im_i);
                        for (i=0; i<x; i++)
            if (search_re_i==arr[i].p_re.re_i && search_im_i==arr[i].p_im.im_i)
            printf("Результат поиска: %d + i*%d", arr[i].p_re.re_i, arr[i].p_im.im_i);
            break;
        default: printf("Ошибка. Введите код 1 или 2.");
        }
     break;
 case 2: printf("\nRe + i*Im\n---------");
     while (i<x)
    {
     printf("\nВведите комплексное число #%d\nRe = ", i+1);
     scanf("%f", &arr[i].p_re.re_f);
     printf("Im = ");
     scanf("%f", &arr[i].p_im.im_f);
     printf("Введенное комплексное число: %.2f + i*%.2f\n---------", arr[i].p_re.re_f, arr[i].p_im.im_f);
         i++;
    }
     float search_f_re, search_f_im;
     short search_kod_f;
     printf("\nПоиск по:\n1. - Номеру записи;\n2. - Значению Re и Im.\nВведите код: ");
     scanf("%d", &search_kod_f);
     switch (search_kod_f)
        {
        case 1: printf("Введите номер записи: ");
            scanf("%d", &i);
            printf("Результат поиска: %.2f + i*%.2f", arr[i-1].p_re.re_f, arr[i-1].p_im.im_f);
                        break;
        case 2: int search_re_f, search_im_f;
            printf("Введите Re: ");
            scanf("%d", &search_re_f);
            printf("Введите Im: ");
            scanf("%d", &search_im_f);
                        for (i=0; i<x; i++)
            if (search_re_f==arr[i].p_re.re_f && search_im_f==arr[i].p_im.im_f)
            printf("Результат поиска: %.2f + i*%.2f", arr[i].p_re.re_f, arr[i].p_im.im_f);
            break;
        default: printf("Ошибка. Введите код 1 или 2.");
        }
     break;
 default: printf("Ошибка. Введите код 1 или 2.");
    }
}
Сначала определяется с каким типом данных работаем (int/float);
вводим массив комплексных чисел вида Re + i*Im;
осуществляем поиск по: 1. номеру массива i; 2. значениям Re и Im.

Так вот в чем вопрос: при работе с вещественным типом данных, если вводить числа с знаками после запятой, например:
1.1+i*1.1
2.2+i*2.2
...
а потом искать по значениям, ввести в поиске допустим Re=1.1 и Im=1.1, то программа не работает, останавливается.
если вводить в массив
1+i*1
2+i*2
...
то все работает как надо.
Из-за чего это может быть?)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
03.03.2014, 00:16     Программа поиска в массиве структур, содержащих объединения
Посмотрите здесь:

Поиск в массиве структур. C++
C++ " Структуры, объединения и определяемые пользователем типы. Массивы структур"
Массив структур. Фун-я удаления и поиска. C++
Программа поиска сотрудников с указанным именем в массиве структур C++
C++ Сортировка в массиве структур
Написать функцию сравнения двух структур с объединениями, содержащих комплексное число C++
C++ Написать функцию поиска структур (записей) с заданными признаками
C++ Создать массив структур, содержащих сведения о различных товарах в магазинах города

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Tulosba
:)
Эксперт С++
4378 / 3221 / 297
Регистрация: 19.02.2013
Сообщений: 9,044
03.03.2014, 17:10     Программа поиска в массиве структур, содержащих объединения #2
Цитата Сообщение от Let_Nov Посмотреть сообщение
Из-за чего это может быть?)
Потому что сравнивать вещественные числа надо хотя бы с какой-то погрешностью. Почитайте про представление чисел с плавающей точкой в компьютере. IEEE-754.
Yandex
Объявления
03.03.2014, 17:10     Программа поиска в массиве структур, содержащих объединения
Ответ Создать тему
Опции темы

Текущее время: 18:42. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru