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

БД.Контейнер - Вектор. - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Вычислить суммы элементов столбцов матрицы http://www.cyberforum.ru/cpp-beginners/thread81581.html
Помогите доработать программу,условие такое :Задана прямоугольная матрица В размера m*n.Вычислить суммы элементов столбцов,номера которых определяются номерами положительных элементов заданного вектора. Вот что имеется из текста,но не правильно работает... #include <iostream.h> #include <fstream.h> #include <iomanip.h> #include <conio.h> const unsigned M=10,N=10;
C++ Обработка текстовых и бинарных файлов в С++ помогите плиз ..... надо решить до завтра обязательно.а у меня не получается(я нуб)...... 1. Создать два бинарных файла, все числа, содержащиеся в обоих файлах одновременно, переписать в третий файл. Дополнительных массивов не использовать. 2. В исходном текстовом файле (создать и ввести) найти слово наибольшей длины. Найденное слово удалить из файла. До-полнительных массивов и файлов не... http://www.cyberforum.ru/cpp-beginners/thread81572.html
C++ Вивод числа на экран, в письменном виде.
Вообще, как сделать, что бы любое число, до 1000, выводилось на экран словами ?? Тоисть, 10 - desyatb, 150 sto pyatdesyat.. ?? зарание спасибо ;)
C++ Вывод содержимого файла
#include <iostream.h> #include <math.h> #include <conio.h> #include <stdio.h> void main() { char ch; FILE *f1; char *st = new char;
C++ Динамическое программирование http://www.cyberforum.ru/cpp-beginners/thread81550.html
Усложнили задачу мне.... : Дан массив A. Необходимо найти максимальную сумму элементов прямоугольного подмассива по всем возможным прямоугольным подмассивам. Нужно решить с помощью динамического программирования. Помогите кто может! Спасибо.
C++ Написание ровнялки текста. День добрый. Не могли бы вы помочь мне в решение одной проблемки. (новую тему заводить не стал, эта подходит) Проблемка состоит в написании ровнялки текста из файла (допустим c:\\1.txt) по ширине консоли (либо по введенной длинне строки. Т.е. если 20 то текст будет вводится в столбик, но это уже не обязательно). Тут уже есть несколько вариантов ровнялок, из них я от части понимаю варинт от... подробнее

Показать сообщение отдельно
closik
0 / 0 / 0
Регистрация: 30.12.2009
Сообщений: 4
30.12.2009, 21:31  [ТС]     БД.Контейнер - Вектор.
Спасибо, я уже разобрался.Все написал, все работает, но попросили сделать числовые значения(а именно "nomerapteki,imeetsya,srokxranenia,stoimost") числовым типом, а не как у меня через char все.Пробовал по разному - не получается, может кто подскажет, что нужно делать?


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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
#include "stdafx.h"
#include <cstdlib>
#include <iostream>
#include <vector>
#include <fstream>
#include <stdio.h>
#include <iomanip>
#include <string>
#include <windows.h>
using namespace std;
         
const int lnomerapteki=3, limeetsya=4, lnazvenie=7, lsrokxranenia=3, ldatapostuplenia=8, lstoimost=5,
  lbuf=lnomerapteki+limeetsya+lnazvenie+lsrokxranenia+ldatapostuplenia+lstoimost+6;
struct inf {
          char nomerapteki[lnomerapteki+1];
          char nazvenie[lnazvenie+1];
          char imeetsya[limeetsya+1];
          char srokxranenia[lsrokxranenia+1];
          char datapostuplenia[ldatapostuplenia+1];
          char stoimost[lstoimost+1];
          inf *next;
          
   }; 
 
void enter(inf &a){
 cout<<endl<<"Введите номер аптеки: ";
 cin>>a.nomerapteki;
 cout<<endl<<"Введите название лекарства: ";
 cin>>a.nazvenie;
 cout<<endl<<"Количество имеющихся в наличии: ";
 cin>>a.imeetsya;
 cout<<endl<<"Введите срок хранения: ";
 cin>>a.srokxranenia;
 cout<<endl<<"Введите дату поступления: ";
 cin>>a.datapostuplenia;
 cout<<endl<<"Введите стоимость: ";
 cin>>a.stoimost;
 }
    
void title(){
     
     cout<<setw(4)<<"№ аптеки "<<"Название"<<" В наличии(штук) "<<" Срок хранения"<<" Дата поступления"<<"  Стоимость  "<<endl;
} 
   
void print(const vector<inf> &v){
     title();
     int n=(int)v.size();
     for (int z=0; z<n; z++)cout<<z+1<<"-"<<setw(5)<<v[z].nomerapteki<<"  "<<v[z].nazvenie<<"      "<<v[z].imeetsya<<"              "<<v[z].srokxranenia<<"          "<<v[z].datapostuplenia<<"        "<<setw(5)<<v[z].stoimost<<endl;
} 
     
void add_to_end(vector<inf> &v, inf &a){
     v.push_back(a);
}
 
void erase(vector<inf> &v,int &i){
     vector<inf>::iterator iter;
     iter=v.begin();
     v.erase(iter+i-1);
}
 
void change(vector<inf> &v,inf &a, int &k){
 v.erase(v.insert(v.begin()+k-1,a)+1);
}
 
void find_datapostuplenia( vector<inf> &v, char* value){
     int n=(int)v.size();
     bool flag=false;
     for(int i=0;i<n;i++){
                      int size=500;
                      char buf[900];
                      strcpy(buf,v[i].datapostuplenia);
                      if ((!(strstr(buf,value)==NULL)) ){
                            title();                           
                           cout<<setw(5)<<v[i].nomerapteki<<"  "<<v[i].nazvenie<<"      "<<v[i].imeetsya<<"              "<<v[i].srokxranenia<<"          "<<v[i].datapostuplenia<<"        "<<setw(5)<<v[i].stoimost<<endl;
                           flag=true;}
     }
     if(!flag) cout<<"Not found"<<endl;
}
 
 
 
void find( vector<inf> &v, char* value){
     int n=(int)v.size();
     bool flag=false;
     for(int i=0;i<n;i++){
                      int size=(int)strlen(v[i].nazvenie);
                      char buf[900];
                      strcpy(buf,v[i].nazvenie);
                      if ((!(strstr(buf,value)==NULL)) ){
                             title();                         
                           cout<<setw(5)<<v[i].nomerapteki<<"  "<<v[i].nazvenie<<"      "<<v[i].imeetsya<<"              "<<v[i].srokxranenia<<"          "<<v[i].datapostuplenia<<"        "<<setw(5)<<v[i].stoimost<<endl;
                           flag=true;}
     }
     if(!flag) cout<<"Not found"<<endl;
}
 
void find_min(vector<inf> &v,int value){
     int n=(int)v.size();
     bool flag=false;
     for(int i=0;i<n;i++){
             int size=(int)strlen(v[i].nomerapteki);
             char buf[900];
             strcpy(buf,v[i].nomerapteki);
             int buf2 = atoi(buf);
             if (buf2==value)
                      {
                      title();
                      cout<<setw(5)<<v[i].nomerapteki<<"  "<<v[i].nazvenie<<"      "<<v[i].imeetsya<<"              "<<v[i].srokxranenia<<"          "<<v[i].datapostuplenia<<"        "<<setw(5)<<v[i].stoimost<<endl;
                      flag=true;
                      }
      
     
             
     
     }
if(!flag) cout<<"Not found"<<endl;
}
     
int main(int argc, char *argv[])
{
   setlocale(0,"Rus");
   char buf[lnomerapteki+1];
   char sbuf [lbuf+1];
   
   
   int n=0;
   int i=0;
   
   
   fstream f1;
   f1.open("test.txt");
   while (f1.getline(sbuf, lbuf+1)) {n++;}
   f1.close();
   vector<inf>v(n);
   
   ifstream f;
   f.open("test.txt");
   if (!f) {cout<<"File not found"<<endl; ;
    return 1;}
    
  
   while (f.getline(sbuf, lbuf)) {
         int j=0; 
         int k=0;  while (sbuf[j]!=' '){ buf[k]=sbuf[j]; k++;j++;} buf[k]='\0';
                   j++;strncpy(v[i].nomerapteki,buf,lnomerapteki);k=0;   
 
                   while (sbuf[j]!=' '){ buf[k]=sbuf[j]; k++;j++;} buf[k]='\0';
                   j++;strncpy(v[i].nazvenie,buf,lnazvenie);k=0;
 
                   while (sbuf[j]!=' '){ buf[k]=sbuf[j]; k++;j++;} buf[k]='\0';
                   j++;strncpy(v[i].imeetsya,buf,limeetsya);k=0;
 
                    while (sbuf[j]!=' '){ buf[k]=sbuf[j]; k++;j++;} buf[k]='\0';
                    j++;strncpy(v[i].srokxranenia,buf,lsrokxranenia);k=0; 
                    
                    while (sbuf[j]!=' '){ buf[k]=sbuf[j]; k++;j++;} buf[k]='\0';
                    j++;strncpy(v[i].datapostuplenia,buf,ldatapostuplenia);k=0;  
                    
                    while (sbuf[j]!='\0'){ buf[k]=sbuf[j]; k++;j++;} buf[k]='\0';
                    j++;strncpy(v[i].stoimost,buf,lstoimost);
                   i++;
         
   }  
 
   
 int check;
inf add;
 
  
  while (1){
        cout<<"1) Вывод"<<endl;
        cout<<"2) Добавить"<<endl;
        cout<<"3) Удалить"<<endl;
        cout<<"4) Изменить"<<endl;
        cout<<"5) Найти"<<endl;
        cout<<"6) Очистить консоль"<<endl;
        cout<<"Введите номер:"<<endl;
        cin>>check;
        int flag=true;
        switch (check){
               
               case 1: { print(v); break;}
               
               case 2: {cout<<endl;  enter(add); add_to_end(v,add);  break;}
               
               case 3:{cout<<endl; cout<<"Какой элемент удалить?: "; cin>>i; erase(v,i); break;}
                
               case 4:{ cout<<endl;  enter(add); cout<<"Какой элемент изменить?: "; cin>>i; change(v,add,i); break;}
               
               case 5:{ char sdate[ldatapostuplenia+1], nomerapteki[lnomerapteki+1],nazvenie[lnazvenie+1], cod[limeetsya+1], k[1]; int min; 
                        cout<<endl<<"1) Поиск по дате поступления"<<endl; cout<<"2) Поиск по названию препарата"<<endl; cout<<"3) Поиск по номеру аптеки"<<endl;
                        cout<<"Введите число: "; cin>>i;
                        switch (i){
                               case 1:{ cout<<endl<<"Введите дату: "; cin>>sdate; cout<<endl; find_datapostuplenia(v,sdate);  break;}
                               case 2:{ cout<<endl<<"Введите название: "; cin>>nazvenie; cout<<endl;  find(v,nazvenie); break; }
                               case 3:{ cout<<endl<<"Введите номер аптеки: "; cin>>min; cout<<endl;  find_min(v,min); break; }
                              
                        }
                        break;
                      }
               case 6: {system("cls");break;}
               
            
 
               
               default:{flag=false;break;}  
                  
                  
        }
        if (!flag) break;
  }
    return 0;
}
 
Текущее время: 03:07. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru