- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在编写一个程序,它使用文件 i/o 接收输入文件并将文件中的数据存储到结构数组中。请记住,我正在向您提供部分代码。不是全部。我知道一切正常,因为一旦我输入数据,我就会打印出所有结构数组。在我尝试对其进行排序之前,正在打印的垃圾发生在函数中。我尝试对其进行排序的那个函数在我的读取文件函数中被调用,我在其中打印了结构数组。在那里,它打印得很完美。当它调用排序函数时,结构数组打印出垃圾。
这是我一直在使用的输入文件的示例:
### 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
我有一个函数,我在其中读取文件并使用字符串流将数据输入到结构数组中。我知道程序的那一部分是正确的,因为我随后打印出了结构数组,并且它们都完美地打印出来了。当我在我的 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
最佳答案
正如许多人评论的那样,您在代码中使用了两种截然不同的范例:您将 C++ 当作 C 来使用。如果您真的在使用 C++,则有更简单的方法来实现这一点。
按照惯例,如果我使用 C++,我会简单地使用运算符重载。
像这样:
class Room {
// not generally a good idea to have public members, but if you must...
public:
std::string building_code;
int room_number;
int max_students;
bool operator == (const Room & other) {
if (max_students != other.max_students)
{
return false;
}
else return room_number == other.room_number && building_code == other.building_code;
}
bool operator < (const Room & other) {
// returning the oposite to ensure descending order.
return max_students > other.max_students;
}
};
然后,您可以将您的 Room
对象放入 std::set
中,它会为您需要的所有房间动态分配足够的内存,并且 使它们按降序排列,如下所示:
#include <set>
std::set<Room> rooms;
room.insert( /* populate a room and put it here */);
room.insert( /* populate a room and put it here */);
这样你就可以像这样输出它们:
cout << "Arranged classrooms in descending order by classroom size: " << endl;
for (std::set<Room>::iterator i = rooms.begin(); i != rooms.end(); i++)
{
cout << i->building_code << " " << i->room_number << " "
<< i->max_students;
cout << endl;
}
我学习的关于 C++ 的一切,我可能是从 here 学到的.
关于c++ - 我的结构数组打印出垃圾,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22204309/
我在使用带有 vector STL 的迭代器时遇到了这个错误。 代码:- #include #include void print_vec(std::vector vec) { auto
JAVA:两个引用“p”&&“pp”之间有区别吗? PrintStream p = new PrintStream(System.out); p.println("lol");
我尝试从主分支中拉出,但收到错误消息: $ git --no-optional-locks -c color.branch=false -c color.diff=false -c color.sta
我面临着一个让我抓狂的问题! 我有一个函数,这个: void load_weapons3(t_env *e, char *name, int x, t_weapon *w) { char
我正在尝试使用 CUDA 中的最小值、最大值、总和和平均值实现并行归约。 这是我目前的主要代码片段。 int main() { const auto count = 8; const
我知道 double free 或 corruption 错误通常是对 big 3 的违规,但在这种情况下,我找不到违规发生的地方。我有一个复制构造函数、析构函数和赋值运算符,适用于任何处理指针的东西
GTK+ 中的“focus”和“focus-in(out)-event”信号有什么区别?哪个先发射?它们与键盘(TAB)和鼠标点击有什么关系。他们互相依赖吗? 我问这个是因为我想在顶层窗口中跟踪当前聚
*** glibc detected *** /home/ghoshs/workspace/Simulator/Debug/Simulator: double free or corruption (
#include #include #include #include using namespace std; #define MAX_WEIGHT 1000000 class Set {
我在服务器上有两个分支一个叫 R2 的分支和一个叫 DEV 的分支我无意中登录了错误的服务器,进入了存储库并执行了GIT pull 源开发但是存储库在 R2 上。所以我意识到我的错误然后尝试通过做一个
我有一个包含循环的大约 1000 个顶点和 3000 个边的有向图。 我试图从给定的顶点找到所有下游(出)路径。 使用以下 Gremlin 查询时 g.V(45712).repeat(out().si
使用 Delphi XE 2 我试图确定缩放方向以将缩放效果应用于图像(TImage),但没有找到执行此操作的函数,并且图像的 OnGesture 事件中的 EventInfo 属性没有此信息. 我见
我正在尝试创建一个 Zoom_image 函数,它使用离散傅里叶变换来缩放灰度图像。如果图像大小小于或等于 4*4 但大小增加,我包含的代码可以工作。它给出“双重释放或损坏(出)中止(核心转储)”错误
当我执行 popAll 函数时,出现以下错误: 双重释放或腐败(出)中止(核心转储) 我想我已经将错误来源缩小到了这个函数。 IntegerStack 是我制作的一个简单的 ADT,其中包含一个名为
我有网络开发背景,我正在尝试创建类似于 this technique 的东西适用于 iOS(使用 Cocoa/Obj C)。我在谷歌搜索资源时遇到了很多困难,因为 iOS 中的“视差”往往指的是 iO
我想实现一个 faceted search对于我的一个项目。我正在使用 PHP5、Mysql 和 Symfony 1.4。显然社区指向Apache Solr这似乎正是我想要完成的。 问题是该网站将在不
我知道有 questions floating around当您没有提供明确的分支名称时,关于来自特定分支的 git pull,但是我想知道即使用户确实指定了不同的分支,是否也可以强制 pull 分支
我正在尝试将我的更改推送到 NAS 上的存储库。它以我无法理解的方式失败。 documentation声明默认情况下 push 仅适用于快进更新。很公平。所以我做了一个 git pull(我的 Rem
我刚开始使用 Oracle 的 Coherence 缓存,我注意到这一点:如果我在缓存中放入一个 ConcurrentHashMap 对象,当我检索它时,我可以看到它被转换为一个普通的 HashMap
我尝试创建一个连接到数据库的线程,从那里获取一些数据并打印到控制台。问题是当该线程完成时抛出异常: 双重免费或腐败(出局)中止(核心转储) 我尝试使用 sqlite3 和 pthread,但这两个并不
我是一名优秀的程序员,十分优秀!