|
ПОмогите Студенту!
#33737254
Ссылка:
Ссылка на сообщение:
Ссылка с названием темы:
Ссылка на профиль пользователя:
|
|
|
|
У меня есть два файла Reis.txt и Vart.txt.Мне надо считать дание с файла и их асоциировать. Поиск осуществляєтса по имен-ключу. Почему если я считиваю дание в масив то при поиске мне кажет что такой записи нет, а когда записиваю но не с файла а поочередно типа:(m.insert(pair <reis, vart>
(reis("Lv-Kiev"),vart("10$")))- то поиск осусчествляєтса.
Как здалать чтоб вариант з файлом работал!!
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.
#include <iostream>
#include <map>
#include <cstring>
#include <conio.h>
using namespace std;
const int size= 5 ;
// клас для сохранения имен-ключей
class reis {
char str[ 20 ];
public:
reis() {strcpy(str, "");}
reis(char *s) {strcpy(str, s);}
char *get() {return str;}
};
// для объектів класу name треба
// визначити оператор < (менше)
bool operator<(reis a, reis b) {
return strcmp(a.get(), b.get()) < 0 ;
}
// клас для сохранения номерів-значень
class vart {
char str[ 20 ];
public:
vart() {strcmp(str, "");}
vart(char *s) {strcpy(str, s);}
char *get() {return str;}
};
typedef map<reis, vart, less<reis> > psevdo;
// друк одной пари ключ/значення
template <class First, class Second> ostream&
operator<<(ostream& out, const pair<First,Second>
&pp){
cout <<"Reis: "<< pp.first.get() << " Vartist: "
<< pp.second.get();
return out;
}
int main() {
int i= 0 ;
FILE *R,*V;
char rs[size][ 20 ],vs[size][ 20 ];
R=fopen("Reis.txt","r");
V=fopen("Vart.txt","r");
map<reis, vart, less<reis> > m;
//НЕ РАБОТАЕТ
/*do
{
fgets (rs,20,R);
fgets (vs,20,V);
if(feof(R)) break;
if(feof(V)) break;
rs[strlen(rs)-1]='\0';
vs[strlen(vs)-1]='\0';
m.insert(pair <reis, vart>
(reis(rs),vart(vs)));
i++;
}
while(true);
fclose(R);
fclose(V);*/
// инициализация асоциативного списку
// именами і номерами
//РАБОТАЕТ
m.insert(pair <reis, vart>
(reis("Lv-Kiev"),vart("10$")));
m.insert(pair <reis, vart>
(reis("Lv-London"), vart("100$")));
m.insert(pair <reis, vart>
(reis("Lv-Odessa"), vart("50$")));
m.insert(pair<reis, vart>
(reis("Lv-Greece"), vart("200")));
//ввод имени ключа
char str[ 20 ];
cout << "Input name: ";
cin >> str;
map <reis, vart, less<reis> >::iterator p;
// поиск номера за именем-ключем
p = m.find (reis(str));
if (p != m.end())
cout << "Znachennia: " << *p;
else
cout << "Imeni v asociatuvnomy spisky nemae\n";
getch();
return 0 ;
}
|
|
|