Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/8: Рейтинг темы: голосов - 8, средняя оценка - 4.88
0 / 0 / 0
Регистрация: 28.11.2016
Сообщений: 53

Подсчет уникальных профессий

16.12.2017, 22:03. Показов 1771. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Суть проблемы: Есть бд содержащая название профессии и прочую инфу. Задача построить диаграмму количества профессий.
Я решил ее с багами, и поэтому там есть не все профессии.
мой алгоритм это построение 2ух массивов где много раз повторяются, например Программист(в первом) - 3(во втором) и тд, у меня не получается ее правильно сделать уникальной, так вот я прошу помощи, либо в алгоритме Подсчета кол-ва, либо помочь мне сделать мой массив уникальным( суть такова что 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
54
 List<string> MasN = new List<string>(); //массив с профессиями
            List<int> Masc = new List<int>();  // массив с количеством проф
            List<int> t = new List<int>();// времянка
            int i = 0;
 
            foreach (var adddep in ourtasks)
            {
                
                    MasN.Add(adddep.position); // получ профессии
 
                    Masc.Add(0); // кол-во этой профессии = 0
                    i++;
                
 
            }
            string ti="";
            ti = MasN[0]; //строка равна первой профессии
            
            for (int j=0; j< MasN.Count; j++)
            {
                ti = MasN[j]; // первая профессия строке 
                for (int k = 0; k < MasN.Count; k++)
                {
                    if (ti == MasN[k])
                    {
                        Masc[j]++; // если встретилась такая же плюсуем
                    }
                }
                
            }
 
 
              for(int m=0; m< MasN.Count; m++)
               {  for (int p = 0; p < MasN.Count-1; p++)
                   {
                       if ((Masc[m] == Masc[p+ 1]) && (MasN[m] == MasN[p + 1])) // алгоритм уникаизации
 
                       {
                           Masc.RemoveAt(m);  // из-за ремува происходит удаление и смена индексов, поэтому мои результаты неверны.
                           MasN.RemoveAt(m);
 
                       }
                   }
 
               }
 
 
         
 
 
              for (int j = 0; j < Masc.Count; j++)
              {
                  chart1.Series["Ser"].Points.AddXY(MasN[j], Masc[j]); // постройка диаграммы
              }
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.12.2017, 22:03
Ответы с готовыми решениями:

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

Подсчет уникальных значений
//считываю из файла данные var log1 = File.ReadAllLines(@&quot;C:\Users\i.a.soboleva\Documents\Мои полученные файлы\log(2).txt&quot;) ...

Подсчет уникальных значений
Доброго времени суток. У меня возникла следующая проблема. Не могу понять как решить подобную задачу. Есть имена и некоторые значения...

10
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18291 / 14214 / 5368
Регистрация: 17.03.2014
Сообщений: 28,891
Записей в блоге: 1
16.12.2017, 22:13
IIoe3D, раз это БД, то нужно написать соответствующий SQL запрос с GROUP BY и COUNT
0
0 / 0 / 0
Регистрация: 28.11.2016
Сообщений: 53
16.12.2017, 23:43  [ТС]
xml бд...
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18291 / 14214 / 5368
Регистрация: 17.03.2014
Сообщений: 28,891
Записей в блоге: 1
16.12.2017, 23:45
IIoe3D, с XML справится LINQ. Покажи структуру документа.
0
0 / 0 / 0
Регистрация: 28.11.2016
Сообщений: 53
19.12.2017, 17:29  [ТС]
XML
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
<?xml version="1.0" standalone="yes"?>
<employees>
  <xs:schema id="employees" xmlns="" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
    <xs:element name="employees" msdata:IsDataSet="true" msdata:Locale="en-US">
      <xs:complexType>
        <xs:choice minOccurs="0" maxOccurs="unbounded">
          <xs:element name="employee">
            <xs:complexType>
              <xs:sequence>
                <xs:element name="id" type="xs:integer" minOccurs="0" />
                <xs:element name="name" type="xs:string" minOccurs="0" />
                <xs:element name="family" type="xs:string" minOccurs="0" />
                <xs:element name="mname" type="xs:string" minOccurs="0" />
                <xs:element name="phonenumber" type="xs:string" minOccurs="0" />
                <xs:element name="exp" type="xs:string" minOccurs="0" />
                <xs:element name="studyfor" type="xs:string" minOccurs="0" />
                <xs:element name="position" type="xs:string" minOccurs="0" />
                <xs:element name="cash" type="xs:string" minOccurs="0" />
                <xs:element name="whereareyou" type="xs:string" minOccurs="0" />
                <xs:element name="date" type="xs:string" minOccurs="0" />
                <xs:element name="months" type="xs:string" minOccurs="0" />
              </xs:sequence>
            </xs:complexType>
          </xs:element>
        </xs:choice>
      </xs:complexType>
    </xs:element>
  </xs:schema>
  <employee>
Добавлено через 2 минуты
Структура выше. А в линг вообще по хмл много функций?
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18291 / 14214 / 5368
Регистрация: 17.03.2014
Сообщений: 28,891
Записей в блоге: 1
19.12.2017, 18:08
Лучший ответ Сообщение было отмечено IIoe3D как решение

Решение

IIoe3D, как-то так:
C#
1
2
3
4
5
6
7
XElement xemployees = XElement.Load("employees.xml");
var result = (
    from xempl in xemployees.Elements("employee")
    select xempl.Element("position").Value into pos
    group pos by pos into posGrp
    select new { Position = posGrp.Key, Count = posGrp.Count() }
).ToArray();
Цитата Сообщение от IIoe3D Посмотреть сообщение
А в линг вообще по хмл много функций?
В LINQ нет специальных функций для XML. Если говорить про LINQ to XML, то это набор классов и расширяющих методов для удобной работы с LINQ. Возможностей там много доступно.
1
0 / 0 / 0
Регистрация: 28.11.2016
Сообщений: 53
19.12.2017, 20:13  [ТС]
спасибо большое)

Добавлено через 48 минут
Я вот сижу и не пойму как обратиться к полученным данным. Резалт это же тип?
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18291 / 14214 / 5368
Регистрация: 17.03.2014
Сообщений: 28,891
Записей в блоге: 1
19.12.2017, 20:17
IIoe3D, result это имя переменной. Её тип массив анонимного типа с свойствами Position и Count. Вот как можно перебрать все элементы:
C#
1
2
3
4
5
6
foreach (var item in result)
{
    string position = item.Position;
    int count = item.Count;
    // ...
}
0
0 / 0 / 0
Регистрация: 28.11.2016
Сообщений: 53
19.12.2017, 20:18  [ТС]
Спасибо, буду подтягивать свои знания в линг, а то вообще ничего не понимаю)
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18291 / 14214 / 5368
Регистрация: 17.03.2014
Сообщений: 28,891
Записей в блоге: 1
19.12.2017, 20:22
IIoe3D, это точно будет только на пользу. И добавь в список неявно типизированные переменные и анонимные типы.

Не по теме:

Цитата Сообщение от IIoe3D Посмотреть сообщение
линг
[зануда вкл]
Если уж произносить LINQ по русски, то это скорее линкью или линк. Что такое "линг" никто не поймет.
[/зануда выкл]

1
0 / 0 / 0
Регистрация: 28.11.2016
Сообщений: 53
19.12.2017, 20:32  [ТС]
Хорошо)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.12.2017, 20:32
Помогаю со студенческими работами здесь

Подсчет уникальных записей
День добрый. Не могу сообразить как задать запрос t1 nomer scheta fio_igd number igd

Подсчет количества уникальных слов
Добрый день. Есть программа для подсчета количества слов тексте: #include &lt;iostream&gt; #include &lt;fstream&gt; #include &lt;string&gt;...

Подсчет уникальных записей в форме
Доброго дня суток! Столкнулся с проблемой, сам решить не могу, подскажите пожалуйста. Есть Форма &quot;Сводный отчет&quot;, в ней...

Подсчет количества уникальных по 2 столбцам
Доброго дня! Помогите пожалуйста подсчитать количество техники. есть большая таблица принтеров с инв.номерами, в которой множество...

Подсчет суммы у уникальных значений
Есть таблицы, одна с пинами, другая с количеством заявок для этих пинов. Прописываю запрос: SELECT `crm_users`.`pin`,...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru