Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
0 / 0 / 0
Регистрация: 19.04.2015
Сообщений: 47

StringGrid анализ, выборка и подсчет данных

19.04.2015, 14:36. Показов 2008. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток!
Такой вопрос: у меня есть StringGrid в который заносятся ФИО студента и его оценки по различным предметам.
Нужно вывести(например, в memo) данные:
-количество сдавших экзамены на 5,
-количество сдавших экзамены на 5 и 4,
-количество сдавших экзамены на 4 и 3,
-количество сдавших экзамен только на 3, средний балл по группе, процент качества(= (кол-во "отл. " + кол-во "хор. ") х 100% / общее кол-во учащихся ),
-процент успеваемости((кол-во "отл. " + кол-во "хор. " + кол-во "уд. ") x 100% / общее кол-во учащихся ) ,
-количество задолжников(те, у кого 2 или н/а), фамилия, имя, отчество задолжника, предметы по которым имеются задолженности.

Помогите пожалуйста хоть чуть-чуть с кодом, не могу понять как сделать выборку такую
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
19.04.2015, 14:36
Ответы с готовыми решениями:

Выборка данных в StringGrid
Надо выбрать данные с условием <4, но почему то не проверяются все данные float var_prog, var_elt; int k; k=0; for (int...

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

Выборка данных, подсчет и вывод на экран
добрый день, всем! Пишу функцию суть которой: 1. Выбирает из таблицы "сотрудники", номера всех сотрудников 2. Подсчитывает из...

2
управление сложностью
 Аватар для Почтальон
1693 / 1306 / 259
Регистрация: 22.03.2015
Сообщений: 7,545
Записей в блоге: 5
19.04.2015, 20:33
Лучший ответ Сообщение было отмечено SatanaXIII как решение

Решение

Примерно вот так:
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
#include <vcl.h>
#pragma hdrstop
 
#include "Select.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
TForm1 *Form1;
//---------------------------------------------------------------------------
__fastcall TForm1::TForm1(TComponent* Owner)
    : TForm(Owner)
{
        StringGrid1->Cells[1][0] = "ФИО";
        StringGrid1->Cells[2][0] = "Оценка";
    StringGrid1->Options << goEditing;
 
}
//---------------------------------------------------------------------------
 
//---------------------------------------------------------------------------
void __fastcall TForm1::BitBtn1Click(TObject *Sender)
{
    int count_of_five = 0;
        int count_of_four = 0;
        int count_two = 0;
        int count_of_three = 0;
        int total_count = 0;
 
        float sred_bal = 0;
        int i = 1;
        String value;
 
        do
        {
 
            value = StringGrid1->Cells[2][i];
                if (value == "5")
                {
                    count_of_five = count_of_five + 1;
                        sred_bal = sred_bal + StrToInt(value);
                }
                else if (value == "4")
                {
                    count_of_four = count_of_four + 1;
                    sred_bal = sred_bal + StrToInt(value);
                }
                else if (value == "3")
                {
                    count_of_three = count_of_three + 1;
                    sred_bal = sred_bal + StrToInt(value);
                }
                else if (value == "2")
                {
                    count_two = count_two + 1;
                    sred_bal = sred_bal + StrToInt(value);
                }
                i = i + 1;
 
                total_count = total_count + 1;
 
        } while(StringGrid1->Cells[2][i] != "");
 
        sred_bal = sred_bal / total_count;
 
        Memo1->Lines->Add("-количество сдавших экзамены на 5: " + IntToStr(count_of_five));
        Memo1->Lines->Add("-количество сдавших экзамены на 4: " + IntToStr(count_of_four));
        Memo1->Lines->Add("-количество сдавших экзамены на 3: " + IntToStr(count_of_three));
        Memo1->Lines->Add("-количество сдавших экзамены на 2: " + IntToStr(count_two));
        Memo1->Lines->Add("Общее количество: " + IntToStr(total_count));
        Memo1->Lines->Add("Средний балл по группе: " + FloatToStr(sred_bal));
 
}
//---------------------------------------------------------------------------
Можно конечно более изящнее, но смысл понятен
1
0 / 0 / 0
Регистрация: 19.04.2015
Сообщений: 47
19.04.2015, 23:59  [ТС]
Очень благодарен вам
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.04.2015, 23:59
Помогаю со студенческими работами здесь

Выборка данных из StringGrid и их построчный поиск в StringList
Здравствуйте, прошу вашей помощи, ибо сам я уже отчаялся найти решение. Суть такая: У меня из екселя переносится таблица в...

Выборка из StringGrid во второй StringGrid
В общем, нужно сделать так, что бы при нажатии на одну из двух кнопок из первого StringGrid делалась выборка и вносилась во второй...

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

Выборка данных из нескольких таблиц. Аналитическая выборка данных
16 Для каждого отдела выбрать отношение зарплаты и комиссионных сотрудников отдела к объему продаж отдела. 17 *Выбрать список штатов в...

Выборка эл-ов в StringGrid
Доброго вам. Задача такая. Таблица состоит из 4 столбцов и n строк. Нужно провести сделать следующее- Нужно поочередно выбрать все...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
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