Разработать программу расчета закупки сырья промышленного предприятия. Данные о закупках хранить в виде массива структур. Итоговая информация должна выводиться на экран в виде таблицы, отсортированной по номеру накладной
использовать структуры, битовые поля и смеси; все логически законченные части программы оформить в виде отдельных функций
Как отсортировать структуру по накладной котороя включает в себя имя и стоимость товара.
Нельзя же просто по полю.Тогда выдет если номер накладной 2 (Батон стоит 100) а номер накладной 1 (Хлеб стоит 200)
То получится что накладная номер 1 уже станет Батон и т.д
Как приминит Битовые поля.И какие еще есть варианты для union?
Заранее благодарен за помощь.
// Console.cpp : Defines the entry point for the console application.
//
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
| #include "stdafx.h"
#include <stdio.h>
#include <iostream>
#include <conio.h>
using namespace std;
union price{int pr1;double pr2;};// объединение .Может принимать как инт так и дабл.
struct item // название товара.
{
char name[10];
short a:5; // битовое поле.
price pr;
}items;
/* Функции */
void input(struct item *n,int size);// Ввод
void output(struct item *n,int size);// вывод результатов.
void sort(struct item *n,int size);// сортировка
/*-------------------*/
int _tmain(int argc, _TCHAR* argv[])
{
short n=0;// количество товаров.
int i;
item it[10];
printf("Vvedite kol-vo tovarov dla zakypki\n");
scanf("%d",&n);
for(i=0;i<n;i++)
printf("Vvedite nomer %d-oi nakladnoi\n",i+1);
scanf("%d",&it[i]);
input(it,n);
_getch();
return 0;
}
void input(struct item *n,int size) // тело функции ввода.
{
for(int i=0;i<size;i++)
{
printf("Vvedite nazvanie %d-ogo tovara\n",i+1);
scanf("%s",&n[i].name);
printf("Vvedite ceny %d tovara\n",i+1);
scanf("%d",&n[i].pr.pr1);
}
}
void output(struct item *n,int size)
{
printf("Nazvanie| Cena |\n");
for(int i=0;i<size;i++)
{
printf("%s",n[i].name);
printf("%d",n[i].pr.pr1);
}
}
/*
void sort(struct item *n,int size)// сортировка.
{
int i;
int j;
for(i=0;i<size-1;i++)
for(j=i+1;j<size;j++)
if(n[i]>n[j])
{
int temp;
temp=n[i];
n[i]=n[j];
n[j]=temp;
}
} |
|
Добавлено через 3 часа 45 минут
Я сам нашел проблему.
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
| // Console.cpp : Defines the entry point for the console application.
//
#include "stdafx.h"
#include <stdio.h>
#include <iostream>
#include <conio.h>
using namespace std;
union price{int pr1;double pr2;};// объединение .Может принимать как инт так и дабл.
struct item // название товара.
{
char name[10];
bool kol:true; // битовое поле.Логическая переменная.
price pr;
int number;// Номер накладной.
}items;
/* Функции */
bool check(bool);
void input(struct item *n,int size);// Ввод
void output(struct item *n,int size);// вывод результатов.
void sortbylist(struct item *n,int size);// сортировкa
/*-------------------*/
using namespace std;
int _tmain(int argc, _TCHAR* argv[])
{
short f=0;// количество товаров.
int i=0;
item it[10];
bool flag=true;
printf("Vvedite kol-vo tovarov dla zakypki <10\n");
std::cin>>f; // ввод через поток
if(f>10)
flag=false;
if(check(flag))
{
input(it,f);
sortbylist(it,f);
output(it,f);
}
else cout<<"Nepravilnoe zna4enie";
_getch();
return 0;
}
bool check(bool f)
{
struct item t;
t.kol=f;
if(t.kol)
return true;
else return false;
}
void input(struct item *n,int size) // тело функции ввода.
{
for(int i=0;i<size;i++)
{
printf("Vvedite nomer nakladnoi\n");
scanf("%d",&n[i].number);
printf("Vvedite nazvanie %d-ogo tovara\n",i+1);
scanf("%s",&n[i].name);
printf("Vvedite ceny %d-ogo tovara\n",i+1);
scanf("%d",&n[i].pr.pr1);
}
}
void output(struct item *n,int size)
{
// printf(" Nazvanie| Cena |\n");
for(int i=0;i<size;i++)
{
printf("Nakladnaya nomer %d:",n[i].number);
printf("Nazvanie:%s|Cena%4d\n",n[i].name,n[i].pr.pr1);
}
}
void sortbylist(struct item *n,int size)// сортировка.
{
struct item t;
int i;
int j;
for(i=0;i<size-1;i++)
for(j=i+1;j<size;j++)
if(n[i].number>n[j].number)
{
t=n[i];
n[i]=n[j];
n[j]=t;
}
} |
|