느낀 ¶
문는 데 로 나기가 무 매다 -_-;
문는 방고; 로그래밍 떻게 나 각게 렸듯...
문는 방고; 로그래밍 떻게 나 각게 렸듯...
단 리링 만 렸다;
- 가: 리링(?) 같 만-_- 단 나봤다; 렬 transpose를 ;;; 단 보는데 듯 

리링 前 ¶
~cpp
#include <stdio.h>
#define ROW 4
#define COL 4
void prt_array(int value[ROW][COL]);
int main(int argc, char* argv[])
{
//int value[4][4]={ {1,2,3}, {3,4,5}, {4,5,6}};
int max;
int i,j;
int value[ROW][COL];
// 4 * 4 렬 공 3 * 3 렬 공 보드로 력 를 ,
for(i=0;i<ROW-1;i++){
for(j=0;j<COL-1;j++){
scanf("%d",&value[i][j]);
}
}
//렬[i][3]는 각 가 를 고,
for(i=0;i<ROW-1;++i){
max=0;
for(j=0;j<COL-1;++j){
if(max < value[i][j]) max = value[i][j];
}
value[i][3] = max;
}
//렬[3][j]는 각 가 를 고,
for(j=0;j<COL-1;++j){
max = 0;
for(i=0;i<ROW-1;++i){
if(max < value[i][j]) max = value[i][j];
}
value[3][j] = max;
}
//렬[3][3]는 가 를 다,
max=0;
for(i=0;i<ROW-1;++i) if(max < value[i][3]) max=value[i][3];
for(i=0;i<COL-1;++i) if(max < value[3][i]) max=value[3][i];
value[3][3] = max;
//들 깔끔게 력는 로그램 라.
prt_array(value);
return 0;
}
//////////////////////////////////////////////////////////////////////////
//// Functions ///////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////
void prt_array(int value[ROW][COL])
{
int i=ROW,j=COL;
for(i=0;i<ROW;++i) {
for(j=0;j<COL;++j) {
printf("%d ",value[i][j]);
}
printf("\n");
}
}
리링 後 ¶
~cpp
#include <stdio.h>
#define ROW 4
#define COL 4
#define DEBUG
void prt_array(int value[ROW][COL]); //렬 력
void swap(int* x,int* y); //두 라미를 바꾸기
void transpose(int (*value)[COL]); //렬 diagonal 기로 transpose
void findmax_row(int (*value)[COL]); // 대값 막 기
int main(int argc, char* argv[])
{
int max;
int i;
#ifdef DEBUG
int value[ROW][COL]={{1,2,3},{3,4,5},{4,5,6}};
#else
int value[ROW][COL];
// 4 * 4 렬 공 3 * 3 렬 공 보드로 력 를 ,
for(i=0;i<ROW-1;i++){
for(j=0;j<COL-1;j++){
scanf("%d",&value[i][j]);
}
}
#endif //DEBUG
//렬[i][3]는 각 가 를 고,
findmax_row(value);
transpose(value);
//렬[3][j]는 각 가 를 고,
findmax_row(value);
transpose(value);
//렬[3][3]는 가 를 다,
max=0;
for(i=0;i<ROW-1;++i) if(max < value[i][3]) max=value[i][3];
for(i=0;i<COL-1;++i) if(max < value[3][i]) max=value[3][i];
value[3][3] = max;
//들 깔끔게 력는 로그램 라.
prt_array(value);
return 0;
}
//////////////////////////////////////////////////////////////////////////
//// Functions ///////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////
void prt_array(int value[ROW][COL])
{
int i=ROW,j=COL;
for(i=0;i<ROW;++i){
for(j=0;j<COL;++j){
printf("%d ",value[i][j]);
}
printf("\n");
}
}
void findmax_row(int (*value)[COL])
{
int i,j,max;
for(j=0;j<ROW-1;++j){
max=0;
for(i=0;i<COL-1;++i){
if(max < value[j][i]) max = value[j][i];
}
value[j][3] = max;
}
}
void transpose(int (*value)[COL])
{
int i,j;
for(i=0;i<ROW;++i)
{
for(j=1+i;j<COL;++j){
swap(&value[i][j],&value[j][i]);
}
}
}
void swap(int* x,int* y)
{
int tmp;
tmp = *x;
*x = *y;
*y = tmp;
}










