알고리즘 교안 p67 질문이 있습니다
156
작성한 질문수 3
int main() {
fill(&a[0], &a[10], 100);
for(int i = 0; i < 10; i++){
cout << a[i] << " ";
}
cout << '\n';
fill(&b[0][0], &b[9][10], 2);
for(int i = 0; i < 10; i++)
{ for(int j = 0; j < 10; j++){
cout << b[i][j] << " "; }
cout << '\n'; }
return 0;
이 코드에서 fill(&a[0], &a[10], 100); 이 부분과 교안에 설명된 부분을 보면 알 수 있듯이 마지막에 쓰이는 인덱스는 포함되지 않아 실제로 a[9]까지 초기화가 가능한 것으로 이해를 하였습니다 그런데 왜 밑에 2차배열을 초기화하는 fill(&b[0][0], &b[9][10], 2);에서는
b[10][10]이 아닌 b[9][10]인지 궁금합니다. 또 b[9][9]로 수정하여 실행해본 결과가
b[9][10]으로 수행한 결과와 같은 이유도 궁금합니다! 긴 질문 죄송합니다!
답변 1
0
안녕하세요 민우님 ㅎㅎ
b[10][10]이 아닌 b[9][10]인지 궁금합니다. 또 b[9][9]로 수정하여 실행해본 결과가
>>
fill의 두번째 인자에는 해당 배열의 끝값 그 다음이 들어가야 합니다.
b[9][9]가 해당 배열의 가장 끝값인 것은 자명합니다. 그러면 그 다음 주솟값은 무엇일까요? b[9][10]이 되게 됩니다.
간단한 예시를 들어볼까요?
#include<bits/stdc++.h>
using namespace std;
int a[3][3];
int main(){
cout << &a[2][1] << '\n';
cout << &a[2][2] << '\n';
cout << &a[2][3] << '\n';
cout << &a[3][3] << '\n';
return 0;
}이 경우
0x10233001c
0x102330020
0x102330024
0x102330030
이런식으로 결과값이 나오게 됩니다. a[2][2] 다음의 주솟값은 [2][3]이 됩니다.
이는 컴파일 환경마다 주솟값은 다를 수 있으나 주솟값의 차이는 동일합니다.
또 b[9][9]로 수정하여 실행해본 결과가 b[9][10]으로 수행한 결과와 같은 이유도 궁금합니다!
>> 음.. 그럴리가 없는데.. 혹시 다시한번 해보시겠어요? 같은 결과가 나오는 코드 공유 부탁드립니다.
또 질문 있으시면 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다.
감사합니다.
코딩 살구 클럽 컴파일 에러
0
4
1
추천 문제
0
7
1
코딩살구클럽 승인
0
9
1
코살구 1주차 1940번 문제 조건과 프라이빗 테스트 불일치 문의
0
21
2
문제를 고민하는 시간 관련
0
26
2
코딩살구클럽
0
38
2
코딩살구클럽 문의
0
37
2
코딩살구클럽 승인
0
35
2
DP 경우의 수 설명이 이해가 되지 않습니다.
0
33
2
3-F 채점 관련 질문
0
31
1
BFS, DFS 활용이 되는 상황에서의 방향성
0
33
2
코딩살구클럽 승인
0
45
2
코딩살구클럽승인
0
39
3
코딩살구클럽 승인
0
54
2
3-D 관련 질문
0
35
2
코살구 회원가입 문의
0
45
2
코살구 로그인 문제
0
65
2
3-A 문제 풀이 관련 질문
0
56
3
2-O 질문 있습니다
0
38
2
2-T 문제에 관한 질문
0
40
2
코딩 살구 클럽 접속 및 사용방법 문의
0
63
2
안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~
0
67
2
코딩살구클럽 로그인문제
0
85
3
코딩 살구 클럽 로그인 문제
0
86
2





