동적배열할당 마방진 생성 질문이요~
후유
1. 입력받은 숫자의 N * N 크기의 배열을 생성한다.
2. 두번째로 입력받은 값을 만족하는 마방진을 생성한다.
즉 20을 입력시
가로합=20 세로합=20 대각선합=20 역대각선합=20
을 만족하는 각각의 배열에 숫자를 생성한다.
숫자는 난수발생기를 이용하여 집어넣는다.
3.배열생성은 동적 메모리 할당을 이용.
이렇게 해서 만드는중인데요..
3일째 이것만 붙들고 있었습니다.
이곳에 막히는 부분 질문도 올리고해서 풀었는데요..
도저히..
진짜 이건...도저히 안되겠네요..
한번 실행해보시면 아실겁니다..
오류가 나요..
배열크기 입력받고
2번째 값을 입력받고 엔터치면 오류뜹니다--
하앍..
도와주세요..
이거 못풀면 다른건 머릿속에 들오지도 않고 의욕도 안생겨요..
이걸 풀어야 뭘 하겠건만..
너무 어려워용..ㅠㅠ
소스입니다~
파일로도 올리고 여기다도 올려요~
한번씩 실행해 보시고 해답좀 가르쳐주세연.ㅠㅠ
#include stdio.h
#include windows.h
#include malloc.h
#include time.h
void arryAllot();
void arryTaking();
void arryValue();
void main(){
int **maBang;
int i,j;
int matching=0;
int cause=0;
int binary;
int count=0;
srand(GetTickCount());
printf(생성할 배열의 크기를 입력하세요 N*N =);
scanf(%d, &matching);
printf(마방진 한줄의 총 합을 입력하세요.);
scanf(%d, &binary);
//입력받은 크기의 동적배열 생성 함수 호출
arryAllot(&maBang,matching);
//배열에 값을 할당하는 함수 호출
arryValue(&maBang,matching);
for(;1;){
//행검사
for(i=0; imatching; i++){
for(j=0; jmatching; j++){
cause += maBang[i][j];
}//end for
if(binary == cause){
count++;
//count값이 matching값과 같으면 행검사 조건을 충족하므로 break;문을 실행
if(count==matching)
break;
}//end if
else{
arryValue(&maBang,matching);
i=0;
j=0;
continue;
}//end else
}//end for 행검사완료
//변수 초기화
count=0;
//열검사
for(j=0; jmatching; j++){
for(i=0; imatching; i++)
cause += maBang[i][j];
if(binary == cause){
count++;
//count값이 matching값과 같으면 행검사 조건을 충족하므로 break;문을 실행
if(count==matching*matching)
break;
}//end if
else{
continue;
arryValue(&maBang,matching);
i=0;
j=0;
}//end else
}//end for 열검사 완료
//대각선 검사
for(i=0; imatching; i++){
for(j=0; jmatching; j++){
if(i==j)
cause += maBang[i][i];
}//end for
}//end for
if(binary != cause){
arryValue(&maBang,matching);
i=0;
j=0;
continue;
}//end if
//역대각선 검사
for(i=0 , j=matching-1; imatching; i++, j--){
cause += maBang[i][j];
}//end for
if(binary == cause)
break;
else if(binary != cause){
arryValue(&maBang,matching);
i=0;
j=0;
continue;
}//end else
}//end for 1번
//완성된 마방진 출력
for(i=0; imatching; i++){
for(j=0; jmatching; j++){
printf(%d , maBang[i][j]);
}
}
//할당된 배열에 메모리 해제하는 함수 호출
arryTaking(&maBang,matching);
}
//메모리 동적할당
void arryAllot(int ***maBang, int matching){
int i;
int **temp = *maBang;
//1차원 동적배열 할당(행을 생성)
temp = (int**)malloc(matching * sizeof(maBang));
//2차원 동적배열 할당(열을 생성)
for(i=0; imatching; i++)
temp[i] = (int*)malloc(matching * sizeof(maBang));
}
//배열에 값을 입력
void arryValue(int ***maBang, int matching){
int i,j;
int **temp = *maBang;
//할당된 maBang배열 메모리 0으로 초기화
memset(temp,0,matching * matching);
//maBang배열에 값을 입력
for(i=0; imatching; i++){
for(j=0; jmatching; j++){
&nb{
temp[i][j] = rand() % 99+1;
}
}
}
//동적할당 메모리 해제
void arryTaking(int ***maBang, int matching){
int i;
for(i=0; imatching; i++){
free(maBang[i]);
}
free(maBang);
system(PAUSE);
}
-
돌심장
int **temp = *maBang;
temp = (int**)malloc(matching * sizeof(maBang)); -- 이렇게 하면 초기화를 두번하게되지않나요?
가리키고있는 포인터녀석을 초기화해서 주소를 잃어버린 소스같네요...(확신은없고 댓글이없길래;;)
구지 temp포인터를 안써도 *maBnag = ~~~ 이렇게 하면될듯;; 근데 이거 무한루프같아요 ~_~;;
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2685477 | 소수점이하 출력하는거요 | 널위해 | 2025-02-18 |
2685449 | printf배우고있는데요 궁금한게있어요 (8) | 꽃큰 | 2025-02-18 |
2685393 | c언어 질문이요.... | 붕붕 | 2025-02-18 |
2685365 | 윈도우7에서 visual studio c++6.0 (1) | 빛길 | 2025-02-17 |
2685317 | segmentation fault가 나요 | 가람 | 2025-02-17 |
2685292 | 다중스택질문 | 올해1살 | 2025-02-17 |
2685231 | C언어와 닷넷에 대해서 질문!! (2) | 설아 | 2025-02-16 |
2685206 | VisualBasic 과 DEV++ 의 장단점과 만든 파일 호환 가능하나요? | 에드워드 | 2025-02-16 |
2685154 | 배열 크기조절 | 해찬솔 | 2025-02-15 |
2685124 | 수정이거 제가 뭐가 잘못한거죠 ? | 아이돌 | 2025-02-15 |
2685096 | 포인터의 고수분들 모두 보세요!! 제발 ㅠ_ㅠ 헷갈려헷갈려..갈려헷.. (7) | 치킨마루 | 2025-02-15 |
2685045 | 전처리기 질문 | 치에미 | 2025-02-14 |
2685016 | 오류 좀 확인해 주시면 감사하겠습니다 | 초코맛사탕 | 2025-02-14 |
2684917 | 알고리즘을 이용한 행렬의 전치// 문제다운 문제네요. | 뿡뿡 | 2025-02-13 |
2684868 | 양방향 연결리스트에서 실행도중 죽는 이유좀 찾아주세요. (2) | 예다움 | 2025-02-13 |
2684844 | 시계프로그램인데 도저히 모르겠어요ㅠ (1) | 비내리던날 | 2025-02-12 |
2684812 | 레포트좀도와주세요ㅠㅠ (2) | 갈매빛 | 2025-02-12 |
2684780 | 채팅창 흉내내보려고하는데요 ㅜ.ㅜ (1) | 바름 | 2025-02-12 |
2684729 | 내일 시험인데 메모리 그리는것좀 도와주세요 ㅠ (1) | 상처주지마 | 2025-02-11 |
2684701 | 버퍼 관련 질문 3가지 (이전거랑 달라요) | 한국녀 | 2025-02-11 |