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

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

Войти
Регистрация
Восстановить пароль
 
andry_kawa
0 / 0 / 0
Регистрация: 27.04.2012
Сообщений: 6
#1

Структура: Разработать программу, которая по заданному значению параметра St находит соответствующий элемент массива - C++

27.04.2012, 13:29. Просмотров 483. Ответов 2
Метки нет (Все метки)

Дан одномерный массив из N элементов, каждый из которых представляет собой запись вида:
C
1
2
3
4
5
struct ZAP
{
unsigned char St [10];
int Dt;
};
Предполагается, что все элементы массива упорядочены в порядке возрастания Dt. Разработать программу, которая по заданному значению параметра St находит соответствующий элемент массива, выводит его на печать (значения St, Dt) и выдает запрос на ввод нового значения Dt. После ввода Dt необходимо скорректировать очередность следования массива так, чтобы упорядоченность оставалась прежней (в порядке возрастания Dt).

желательно через prinf и scanf
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
27.04.2012, 13:29
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Структура: Разработать программу, которая по заданному значению параметра St находит соответствующий элемент массива (C++):

Написать программу, которая запрашивает размерность двумерного массива, заполняет его случайными числами от 5 до 15 и находит максимальный элемент в м - C++
Написать программу, которая запрашивает размерность двумерного массива, заполняет его случайными числами от 5 до 15 и находит максимальный...

Создать программу, которая находит папку (файл) по заданному пути и “выдаёт” о ней общие сведения - C++
Здравствуйте форумчане, обращаюсь я к вам с нескромной просьбой, а именно, не могли бы вы сделать псевдокод или попросту за меня сделать...

Составить программу которая по заданному значению соответствующего элемента, вычисляла бы значения всех остальных элементов треугольника. - C++
В общем суть задачи такова: Дан равнобедренный треугольник с катетом - a, гиппотенузой - b, высотой - h и площадью - s, и, нужно...

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

Функция, которая находит элемент массива - C++
Здравствуйте,задание:написать функцию,которая ищет элемент в массиве.Я не понимаю почему не получается,я перепробовал кучи вариантов,но...

Составить программу которая находит максимальный элемент - C++
Дана квадратная матрица А порядку n. Составить программу, которая находит максимальный элемент и все элементы, розположенные в одном ряде...

2
zitxbit
88 / 740 / 75
Регистрация: 11.04.2012
Сообщений: 971
27.04.2012, 16:07 #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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
#include <stdio.h>
#include <conio.h>
#include <string.h>
 
typedef struct ZAP
{
    unsigned char St[10];
    int Dt;
} ZAP;
 
#define __countof(ptr) sizeof(ptr) / sizeof(ptr[0]) \
 
int _tmain(int argc, _TCHAR* argv[])
{
    static ZAP lpZap[] = { { "A", 5  }, { "B", 6 },  { "C", 14 },
                           { "D", 16 }, { "E", 25 }, { "F", 26 },
                           { "G", 34 }, { "H", 48 }, { "I", 51 },
                           { "J", 66 }, { "K", 75 }, { "M", 87 } };
    
    do {
          static char* psz = new char[256];
          printf("\nVvedite St = "); scanf("%s",psz);
 
          static char* pszSt = "\0"; int* nDt = NULL;
          for (int i = 0; i < __countof(lpZap) && !nDt; i++)
               if (!strcmp((char*)lpZap[i].St, psz))
               {
                  pszSt = (char*)lpZap[i].St;
                  nDt = &lpZap[i].Dt;
               }
 
          printf("\nFound St = %s Dt = %d\n",pszSt,*nDt);
 
          if (strcmp("\0",pszSt) < 0 && nDt != NULL)
          {
              printf("\nVvedite novoe znachenie St = : ");
              scanf("%s",pszSt);
              printf("\nVvedite novoe znachenie Dt = : ");
              scanf("%d",nDt);
 
              for (int q = 0; q < __countof(lpZap); q++)
                   for (int k = 0; k < __countof(lpZap); k++)
                        if (lpZap[k].Dt > lpZap[q].Dt)
                        {
                            ZAP temp = lpZap[k];
                            lpZap[k] = lpZap[q];
                            lpZap[q] = temp;
                        }
          }
    } while(true);
 
    return 0;
}
2
andry_kawa
0 / 0 / 0
Регистрация: 27.04.2012
Сообщений: 6
27.04.2012, 19:56  [ТС] #3
спасибо большое) очень помогли)
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
27.04.2012, 19:56
Привет! Вот еще темы с ответами:

Написать программу бинарного поиска элемента массива равного заданному значению - C++
Помогите написать программу бинарного поиска элемента массива равного заданному значению, в которой новое значение индекса m определялось...

составить программу, которая находит максимальное и минимальное значение среди элементов одномерного массива Y, которая состоит из N целых чисел - C++
составить программу, которая находит максимальное и минимальное значение среди элементов одномерного массива Y, которая состоит из N целых...

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

Написать функцию, которая находит минимальный элемент одномерного массива - C++
Написать функцию, которая находит минимальный элемент одномерного массива.


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

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

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