enum Direction {
NORTH = 0,
EAST = 1,
SOUTH = 2,
WEST = 3 };
struct Point {
int x, y; };
class Path {
private:
Point visited[10000];
int visited_positions;
bool circular;
public:
Path() {
visited_positions = 1;
circular = 0;
Point p;
p.x = 0;
p.y = 0;
visited[0] = p;
}
void add_point(Point p) {
if(!circular) {
for(int i = 0; i < visited_positions; i++) {
if(visited[i].x == p.x && visited[i].y == p.y) {
circular = true;
break;
}
}
}
visited[visited_positions] = p;
visited_positions++;
}
bool is_circular() {
return circular;
}
};
class Robot {
private:
Point position;
Direction direction;
Path path;
public:
Robot() {
position.x = 0;
position.y = 0;
direction = NORTH;
}
void turn_left() {
direction = static_cast<Direction>((direction + 3) % 4);
}
void turn_right() {
direction = static_cast<Direction>((direction + 1) % 4);
}
void forward() {
switch (direction) {
case NORTH:
position.y++;
break;
case EAST:
position.x++;
break;
case SOUTH:
position.y--;
break;
case WEST:
position.x--;
break;
}
path.add_point(position);
}
Point get_position() {
return position;
}
bool has_gone_in_a_loop() {
return path.is_circular();
} };
int main() {
int test_cases;
cin >> test_cases;
string instruction_string;
for(int tc = 0; tc != test_cases; tc++) {
cin >> instruction_string;
Robot skundi;
for(size_t i = 0; i < instruction_string.size(); i++) {
switch(instruction_string[i]) {
case 'H':
skundi.turn_right();
break;
case 'V':
skundi.turn_left();
break;
case 'F':
skundi.forward();
break;
}
}
if(skundi.has_gone_in_a_loop()) {
cout << "Circular" << endl;
}
else {
cout << "OK" << endl;
}
}
return 0; }
이것은 숙제 임으로 어떤 힌트에도 감사드립니다. (아무런 경품도 : D) 이것들은 내가 겪고있는 valgrind 오류입니다. 당신이 ("아마도 손실"로 나타납니다 그 이유는) 하나로 볼 수 있지만C++ 로봇, 숙제 과제 - 메모리 누수로 인한 valgrind 오류가 발생합니다. 일부 힌트가 정말 필요합니다
Memcheck, a memory error detector
Invalid read of size 8
Using Valgrind:
**HEAP SUMMARY:**
in use at exit: 16,352 bytes in 1 blocks
total heap usage: 14 allocs, 13 frees, 28,907 bytes allocated
16,352 bytes in 1 blocks are possibly lost in loss record 1 of 1
at 0xX: operator new(unsigned long) (vg_replace_malloc.c:298....)
by 0xX: std::string::_Rep::_S_create(unsigned long, unsigned long, std::allocator const&) (in /usr/lib64/libstdc++.so.6.0.13)
by 0xX: std::string::_Rep::_M_clone(std::allocator const&, unsigned long) (in /usr/lib64/libstdc++.so.6.0.13)
by 0xX: std::string::reserve(unsigned long) (in /usr/lib64/libstdc++)
by 0xX: std::basic_istream >& std::operator>>, std::allocator >(std::basic_istream >&, std::basic_string, std::allocator >&) (in /usr/lib64/libstdc++)
**LEAK SUMMARY:**
definitely lost: 0 bytes in 0 blocks
indirectly lost: 0 bytes in 0 blocks
possibly lost: 16,355 bytes in 1 blocks
still reachable: 0 bytes in 0 blocks
suppressed: 0 bytes in 0 blocks
For counts of detected and suppressed errors, rerun with: -v
ERROR SUMMARY: 1 errors from 1 contexts (suppressed: 6 from 6)
오류를 올바르게 해석하면 valgrind는 memleak을'cin >> instruction_string;'으로 가정합니다. 그러나 이것은 memleak이 아닙니다. 또한 valgrind는 이것을 '가능한 손실'이라고 선언합니다. 'new'로 직접 일하지 않으면 memleaks를 결코 두려워해서는 안됩니다. 코드에는 자동 저장 변수 만 포함됩니다. – Paranaix