동적배열할당 마방진 생성 질문이요~
후유
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 = ~~~ 이렇게 하면될듯;; 근데 이거 무한루프같아요 ~_~;;
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2676182 | 숫자 순서대로 배열하는법 | 권뉴 | 2024-11-24 |
2676152 | 기본적인거 하나 질문드립니다. | 개미 | 2024-11-24 |
2676124 | 함수선언관련 질문이에요~...털썩..수정완료 (2) | 가지 | 2024-11-24 |
2676092 | C언어 책 (2) | 아서 | 2024-11-24 |
2676065 | 웹사이트 또는 메신저 등에서 원하는 텍스트를 검사하는방법?? (1) | 모든 | 2024-11-23 |
2676033 | 배열 기초연습중 발생하는 에러 ㅠㅜ... | Creative | 2024-11-23 |
2676005 | keybd_event 게임 제어 | 영글 | 2024-11-23 |
2675900 | 진짜기본적인질문 | 글길 | 2024-11-22 |
2675845 | 수정좀해주세요ㅠㅠㅠ | 해골 | 2024-11-21 |
2675797 | 병합 정렬 소스 코드 질문입니다. (2) | 도래솔 | 2024-11-21 |
2675771 | 큐의 활용이 정확히 어떻게 되죠?? | 해긴 | 2024-11-21 |
2675745 | 도서관리 프로그램 질문이요 | 도리도리 | 2024-11-20 |
2675717 | 2진수로 변환하는것! (3) | 동생몬 | 2024-11-20 |
2675599 | for문 짝수 출력하는 법 (5) | 널위해 | 2024-11-19 |
2675575 | Linux 게시판이 없어서.. | 첫삥 | 2024-11-19 |
2675545 | 구조체 이용할 때 함수에 자료 넘겨주는 것은 어떻게 해야 하나요? | 아연 | 2024-11-19 |
2675518 | 사각형 가로로 어떻게 반복해서 만드는지좀.. 내용 | 신당 | 2024-11-18 |
2675491 | !느낌표를 입력하는것은 어떻게합니까~~?ㅠㅠ (5) | 사지타리우스 | 2024-11-18 |
2675411 | 파일입출력으로 받아온 파일의 중복문자열을 제거한 뒤 파일출력 | 앨버트 | 2024-11-17 |
2675385 | 링크드리스트 주소록 질문드립니다. (1) | 겨루 | 2024-11-17 |