알고리즘 교안 p67 질문이 있습니다
153
작성한 질문수 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점은 제게 큰 힘이 됩니다.
감사합니다.
4 - A
0
22
2
코딩살구클럽 입장이 안됩니다
0
60
2
4-F 경우의 수 질문입니다.
0
32
2
코딩살구클럽 가입이 안됩니다.
0
74
2
살구 클럽에 대한 질문있습ㄴ디ㅏ
0
54
1
교안 158페이지 문의드립니다
0
44
2
코딩살구클럽 관련 건의사항
0
114
1
코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다
0
44
1
진행 방법 질문드립니다!
0
80
2
2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.
0
63
2
2주차 개념#12 트리 순회
0
32
2
백준사이트가 종료된다고 합니다.
0
315
2
백준 서비스 종료
9
950
1
sk 하이닉스 코테 대비
0
385
2
3-G 최댓값 질문
0
54
1
모듈러 연산 값이 10이 아닌 경우도 있지 않나요?
0
84
2
3-I 코드 질문드립니다.
0
65
2
3-N 질문 있습니다.
0
68
2
학습방법
0
105
2
4-H 질문 있습니다 (코드 리뷰)
0
69
2
코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.
0
182
2
2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.
0
72
2
2주차 개념 #4-2. 인접행렬 질문있습니다.
0
65
2
1-A 문제풀이 후 궁금한 점이 생겨서 질문드립니다.
0
53
2





