【发布时间】:2014-03-05 17:02:56
【问题描述】:
我正在编写一个程序,它使用文件 i/o 接收输入文件并将文件中的数据存储到结构数组中。请记住,我正在为您提供部分代码。不是全部。我知道一切工作正常,因为一旦输入数据,我就会打印出所有的结构数组。在我尝试对其进行排序之前,正在打印的垃圾发生在函数中。我尝试对其进行排序的那个函数在我的读取文件函数中调用,我在其中打印了结构数组。在那里,它打印得很完美。当它调用 sort 函数时,结构数组会打印出垃圾。
这是我一直在使用的输入文件示例:
### building room_number capacity
SAL 210 30
OHE 100 120
OHE 120 50
### ID prefix course# sect# #minutes #mtgsperweek #students
20001 CSCI 101 01 110 2 40
20002 CSCI 101 02 110 2 60
20003 CSCI 101 03 110 2 100
20004 CSCI 103 01 90 2 50
20005 CSCI 103 02 90 2 50
20006 CSCI 103 03 90 2 75
20007 CSCI 104 01 80 2 50
20008 CSCI 104 02 80 2 50
20009 CSCI 109 01 90 1 25
20010 CSCI 109 02 90 1 25
20011 CSCI 109 03 90 1 25
20012 CSCI 109 04 90 1 25
### ID days_constraint start_constraint end_constraint
20001 MW 1000 1400
20002 MW 1000 1400
20003 TR 1000 1400
20004 TR 0800 1200
20005 TR 0800 1200
20006 TR 0800 1200
20007 MW 0800 1200
20008 MW 0800 1200
20009 M 0800 1200
20010 M 0800 1200
20011 T 0800 1200
20012 T 0800 1200
我有一个函数,我在其中读取文件并使用 stringstream 将数据输入到结构数组中。我知道程序的一部分是正确的,因为我后来打印出结构数组,它们都打印得很好。当我在 read_File 函数中调用一个名为 sort_ByClassroomSize 的新函数时,问题就出现了,在该函数中,我试图按教室容量的降序对结构数组进行排序。
这是结构:
struct Room {
char building_code[4];
int room_number;
int max_students;
};
我声明一个指针,然后根据用户输入的房间数量动态分配。
struct Room* roomsPtr;
roomsPtr = new struct Room[room_size];
其中 room_size 是一个计数器,用于计算声明房间的行数。
这是我将数据输入到结构中的方式:
if( !(line[0] == '-' && line[1] == '-') ) {
stringstream ss;
ss << line;
ss >> roomsPtr[i].building_code;
ss >> roomsPtr[i].room_number;
ss >> roomsPtr[i].max_students;
if( ss.fail() ) { //checks format; terminates program if incorrect.
cout << "The file has been formatted incorrectly." << endl;
return;
}
//prints lines in section 1.
cout << roomsPtr[i].building_code << " " << roomsPtr[i].room_number <<
" " << roomsPtr[i].max_students << endl;
问题出在排序功能上:
void order_ClassroomsBySize(int num_rooms) { //arranges classrooms in descending order
by classroom size
struct Room temp_value;
//prints the array of structs before arrangement
cout << endl;
cout << "Arranged classrooms in descending order by classroom size: " << endl;
for(int i = 0; i < num_rooms; i++) {
cout << roomsPtr[i].building_code << " " << roomsPtr[i].room_number << " "
<< roomsPtr[i].max_students;
cout << endl;
}
}
//arranges the array of structs in descending order by classroom size
for(int i = 0; i < num_rooms; i++) {
for(int j = 0; j < num_rooms - 1; j++) {
if(roomsPtr[j].max_students < roomsPtr[j+1].max_students) {
temp_value = roomsPtr[j];
roomsPtr[j] = roomsPtr[j+1];
roomsPtr[j+1] = temp_value;
}
}
}
//prints the array of structs after arrangement
cout << endl;
cout << "Arranged classrooms in descending order by classroom size: " << endl;
for(int i = 0; i < num_rooms; i++) {
cout << roomsPtr[i].building_code << " " << roomsPtr[i].room_number << " "
<< roomsPtr[i].max_students;
cout << endl;
}
}
我的程序正在打印以下内容:
### building room_number capacity
SAL 210 30
OHE 100 120
OHE 120 50
### ID prefix course# sect# #minutes #mtgsperweek #students
20001 CSCI 101 01 110 2 40
20002 CSCI 101 02 110 2 60
20003 CSCI 101 03 110 2 100
20004 CSCI 103 01 90 2 50
20005 CSCI 103 02 90 2 50
20006 CSCI 103 03 90 2 75
20007 CSCI 104 01 80 2 50
20008 CSCI 104 02 80 2 50
20009 CSCI 109 01 90 1 25
20010 CSCI 109 02 90 1 25
20011 CSCI 109 03 90 1 25
20012 CSCI 109 04 90 1 25
### ID days_constraint start_contsraint end_constraint
20001 MW 1000 1400
20002 MW 1000 1400
20003 TR 1000 1400
20004 TR 0800 1200
20005 TR 0800 1200
20006 TR 0800 1200
20007 MW 0800 1200
20008 MW 0800 1200
20009 M 0800 1200
20010 M 0800 1200
20011 T 0800 1200
20012 T 0800 1200
Arranged classrooms in descending order by classroom size:
course# sect# #minutes OHE 593851250 1667592992
t# #minutes OHE 1970170221 544433524
OHE 120 50
Arranged classrooms in descending order by classroom size:
course# sect# #minutes OHE 593851250 1667592992
t# #minutes OHE 1970170221 544433524
OHE 120 50
【问题讨论】:
-
为什么不使用
std::vector并使用std::sort进行排序?当然std::string用于字符串。从长远来看,使用 standard library 中的工具将帮助您成为 C++ 程序员。 -
@JoachimPileborg 我是 C++ 新手。我还没有学过向量!这是我写的第三个程序。我也没有上课。我刚学完结构体和指针。
-
我不想让你失望,但你可能会在几年内学习结构和指针。此外,结构是所有成员都公开的类(可能没有明确的成员函数)。
-
@JonathanLeffler 这不是重点。关键是我还没有学过向量。我正在介绍南加州大学的编程课程。而且,我想使用我在课堂上学到的概念,以便我能够理解它们并与它们一起练习。
-
目前这只是伪装的 C,而不是真正的 C++。你确定你的老师想教你C++,还是仅仅是C?这是两种不同的语言。