모바일 오유 바로가기
http://m.todayhumor.co.kr
분류 게시판
베스트
  • 베스트오브베스트
  • 베스트
  • 오늘의베스트
  • 유머
  • 유머자료
  • 유머글
  • 이야기
  • 자유
  • 고민
  • 연애
  • 결혼생활
  • 좋은글
  • 자랑
  • 공포
  • 멘붕
  • 사이다
  • 군대
  • 밀리터리
  • 미스터리
  • 술한잔
  • 오늘있잖아요
  • 투표인증
  • 새해
  • 이슈
  • 시사
  • 시사아카이브
  • 사회면
  • 사건사고
  • 생활
  • 패션
  • 패션착샷
  • 아동패션착샷
  • 뷰티
  • 인테리어
  • DIY
  • 요리
  • 커피&차
  • 육아
  • 법률
  • 동물
  • 지식
  • 취업정보
  • 식물
  • 다이어트
  • 의료
  • 영어
  • 맛집
  • 추천사이트
  • 해외직구
  • 취미
  • 사진
  • 사진강좌
  • 카메라
  • 만화
  • 애니메이션
  • 포니
  • 자전거
  • 자동차
  • 여행
  • 바이크
  • 민물낚시
  • 바다낚시
  • 장난감
  • 그림판
  • 학술
  • 경제
  • 역사
  • 예술
  • 과학
  • 철학
  • 심리학
  • 방송연예
  • 연예
  • 음악
  • 음악찾기
  • 악기
  • 음향기기
  • 영화
  • 다큐멘터리
  • 국내드라마
  • 해외드라마
  • 예능
  • 팟케스트
  • 방송프로그램
  • 무한도전
  • 더지니어스
  • 개그콘서트
  • 런닝맨
  • 나가수
  • 디지털
  • 컴퓨터
  • 프로그래머
  • IT
  • 안티바이러스
  • 애플
  • 안드로이드
  • 스마트폰
  • 윈도우폰
  • 심비안
  • 스포츠
  • 스포츠
  • 축구
  • 야구
  • 농구
  • 바둑
  • 야구팀
  • 삼성
  • 두산
  • NC
  • 넥센
  • 한화
  • SK
  • 기아
  • 롯데
  • LG
  • KT
  • 메이저리그
  • 일본프로야구리그
  • 게임1
  • 플래시게임
  • 게임토론방
  • 엑스박스
  • 플레이스테이션
  • 닌텐도
  • 모바일게임
  • 게임2
  • 던전앤파이터
  • 마비노기
  • 마비노기영웅전
  • 하스스톤
  • 히어로즈오브더스톰
  • gta5
  • 디아블로
  • 디아블로2
  • 피파온라인2
  • 피파온라인3
  • 워크래프트
  • 월드오브워크래프트
  • 밀리언아서
  • 월드오브탱크
  • 블레이드앤소울
  • 검은사막
  • 스타크래프트
  • 스타크래프트2
  • 베틀필드3
  • 마인크래프트
  • 데이즈
  • 문명
  • 서든어택
  • 테라
  • 아이온
  • 심시티5
  • 프리스타일풋볼
  • 스페셜포스
  • 사이퍼즈
  • 도타2
  • 메이플스토리1
  • 메이플스토리2
  • 오버워치
  • 오버워치그룹모집
  • 포켓몬고
  • 파이널판타지14
  • 배틀그라운드
  • 기타
  • 종교
  • 단어장
  • 자료창고
  • 운영
  • 공지사항
  • 오유운영
  • 게시판신청
  • 보류
  • 임시게시판
  • 메르스
  • 세월호
  • 원전사고
  • 2016리오올림픽
  • 2018평창올림픽
  • 코로나19
  • 2020도쿄올림픽
  • 게시판찾기
  • 게시물ID : programmer_18321
    작성자 : 훗날닭집사장
    추천 : 0
    조회수 : 495
    IP : 113.198.***.32
    댓글 : 3개
    등록시간 : 2016/08/31 21:23:51
    http://todayhumor.com/?programmer_18321 모바일
    C) 알고리즘 문제 오답이 발생하는 이유가 뭘까요? (코드 김 주의)
    옵션
    • 본인삭제금지
    우선 알고리즘 문제에 대한 링크입니다.
     
     
    코드가 길어 죄송합니다 최대한 세세하게 주석을 달아놓겠습니다.
    또 본래 표준입출력으로 해야하나 우선 파일입출력 형식으로 했습니다 (이것 때문에 오답처리 되는것은 아닌게
    파일입출력의 경우 정답이여도 런타임 에러가 발생하는데 이 코드는 아예 틀렸습니다 라는 오답문구가 나옵니다. ㅠㅠ)
     
    #include <stdio.h>
    #include <stdlib.h>
    #pragma warning(disable: 4996) // scanf 관련해서 발생하는 에러 C4996을 해소하기 위해 삽입했습니다
     
    int main()
    {
     FILE *fp = fopen("Input.txt", "r");
     int d, i, j, k, l; // 반복문을 위한 변수
     int T; // 총 테스트케이스 반복 횟수
     int m, n, a, b, p, q; // m = 경기 수 / n = 팀 수 / a,b = 대결을 하는 두 팀 / p,q = 두 팀의 득점
     int goal = 0; // 총 득점
     int miss = 0; // 총 실점
     int twogoal = 0; // 득점 제곱
     int twomiss = 0; // 실점 제곱
     int MAX = 0; // 최대 기대값
     int MIN = 0; // 최소 기대값
     int **score = NULL; // 득,실점이 들어갈 2차원 배열 동적할당
     float *W = NULL; // 기대값이 들어갈 1차원 배열 동적할당
     
     if (fp == NULL)
     {
      printf("File Open Error.\n");
      exit(1);
     }
     fscanf(fp, "%d", &T);
     
     for (i = 0; i < T; i++)
     {
      fscanf(fp, "%d %d", &n, &m);
      score = (int **)malloc(sizeof(int *) * m);
      score[0] = (int *)malloc(sizeof(int) * n*m);
      W = (float *)malloc(sizeof(float) * n);
     
      for (d = 1; d < m; d++)
      {
       score[d] = score[d - 1] + n;
      }
     
      for (d = 0; d < m; d++)
      {
       for (l = 0; l < 2; l++)
       {
        score[d][l] = 0;
       }
      }
     
      for (d = 0; d < n; d++)
      {
       W[d] = 0;
      }
     
      for (j = 0; j < m; j++)
      {
       fscanf(fp, "%d %d %d %d", &a, &b, &p, &q);
     
       if ((a + b) > (m + n))
       {
        printf("파일 크기 에러.\n");
       }
     
       score[a - 1][0] += p;
       score[a - 1][1] += q;
       score[b - 1][0] += q;
       score[b - 1][1] += p;
      }
     
      for (k = 0; k < n; k++)
      {
       goal += score[k][0];
       miss += score[k][1];
       twogoal = goal*goal;
       twomiss = miss*miss;
     
       if (goal == 0 && miss == 0)
       {
        W[k] = 0;
       }
       else
       {
        W[k] = (float)(1000 * twogoal / (twogoal + twomiss));
       }
       goal = 0;
       miss = 0;
      }
     
      MAX = (int)W[0];
      MIN = (int)W[0];
     
      for (d = 1; d < n; d++)
      {
       if (MIN > W[d])
       {
        MIN = (int)W[d];
       }
       else if (MAX < W[d])
       {
        MAX = (int)W[d];
       }
      }
     
      printf("%d\n%d\n", MAX, MIN);
      MAX = 0;
      MIN = 0;
     }
     
     fclose(fp);
     free(score[0]);
     free(score);
     free(W);
     return 0;
    }
     
     
    문제에 대해서 어떻게 접근하고자 했냐면
     
    문제에서 입력예제를 보면 각각의 팀을 1번팀, 2번팀, 3번팀.. 등으로 지칭하는데
     
    가령 1번팀의 총 득점이 10, 총 실점이 5라면
    score[0][0] += 10
    score[0][1] += 5
     
    2번팀의 총 득점이 7, 실점이 4라면
    score[1][0] += 7
    score[1][1] += 4...
     
    이런 식으로 n번째 배열마다 2개의 득/실점을 활용하는 식으로 접근해봤습니다.
     
    이렇게 하니 입력예제를 변경해도 값은 제대로 뜨는데, 채점에서는 오답이라고 계속 뜨는게 도통 이유를 모르겠어서 올려봅니다.
     
    아예 싹 갈아엎어야 할 문제일까요? ㅠ.ㅠ
     

    이 게시물을 추천한 분들의 목록입니다.
    푸르딩딩:추천수 3이상 댓글은 배경색이 바뀝니다.
    (단,비공감수가 추천수의 1/3 초과시 해당없음)

    죄송합니다. 댓글 작성은 회원만 가능합니다.

    번호 제 목 이름 날짜 조회 추천
    18353
    앱만들때 앱 로딩전 이미지띄우는것 질문 [2] 베스트금지본인삭제금지외부펌금지 kasiotori 16/09/05 09:47 455 0
    18352
    [스압] IT학원에 관한 이야기 + 최종 프로젝트로 만든 프로그램 [11] 본인삭제금지 soseullua 16/09/05 09:25 994 6
    18351
    tcp 패킷에서 window scale 값 질문있습니다.. [1] 베스트금지베오베금지본인삭제금지 별찌아라 16/09/05 01:12 311 0
    18349
    안녕하세요~프로그래밍 초짜인데 공부 순서 좀 여쭐게요 [7] 라면먹고가죵 16/09/04 22:08 533 0
    18348
    이 함수 정의에서 문제되는게 있나요? [3] 본인삭제금지 훗날닭집사장 16/09/04 15:10 418 0
    18347
    파이썬은 웹프로그랭언어로도 쓰나요? [9] 사색을하자 16/09/03 21:34 835 0
    18346
    IDE에 귀신이 들었어요 [4] 유코 16/09/03 19:07 719 0
    18345
    C#질문 좀 드립니다. [4] 밥무라 16/09/03 15:24 697 0
    18343
    제대후 복학 할려는데 좀 막막해서 글올립니다. [2] 브롤1라프 16/09/03 13:21 404 0
    18342
    부동소수점 기수정렬시 문제? [3] 창작글본인삭제금지 쌓인세타 16/09/03 08:58 467 0
    18341
    라라벨이 국내에 쓰기 시작한게 얼마안되는 걸로 알고 있는데 [4] nambak80 16/09/03 06:42 559 0
    18340
    포인터 동적할당과 관련된 질문입니다.(본삭금) [19] 본인삭제금지 치쿠린 16/09/02 22:53 676 0
    18339
    stdlib 퀵소트 사용시 2차원배열은 정렬할 수 없나요? [5] 본인삭제금지 카토리 16/09/02 20:57 8954 0
    18336
    mongodb 관련해서 하나만 여쭤 봐도 될까요? [2] 본인삭제금지 자유해결사 16/09/02 17:36 555 0
    18335
    취직이 안되서 금연07132016 16/09/02 13:40 555 5
    18334
    C/C++은 보통 채용조건에 같이 묶여있나요? [1] 본인삭제금지 카토리 16/09/02 13:15 640 0
    18333
    c++ 도움좀... [6] 본인삭제금지 금연07132016 16/09/02 11:49 470 0
    18332
    깃허브 오류 질문있습니다. [7] 본인삭제금지 초보오유러 16/09/02 00:05 444 0
    18331
    C/C++ 프로그래밍 입문자가 참고하면 좋은 사이트, 책 추천 바랍니다! [8] 딜래탕트 16/09/01 22:31 756 1
    18330
    초보주의, C++) 포인터로 매개변수 받는것을 배열로 바꿀때 질문입니다. [11] 본인삭제금지 치쿠린 16/09/01 18:28 2410 0
    18329
    보통 어느정도 시간을 투자 하시면서 공부 하세요? [7] 야간산책 16/09/01 17:43 601 0
    18328
    안녕하세요 선배님들 플밍입문자 질문이있습니다 [5] 본인삭제금지 아참 16/09/01 17:19 403 0
    18327
    데이터 ip주소 [1] 성덕썬 16/09/01 16:25 553 0
    18326
    C언어 문제 제출시 시간초과의 원인이 무엇일까요? [7] 본인삭제금지 카토리 16/09/01 09:07 1091 0
    18324
    자바스크립트 제이쿼리 (웹퍼블리셔 질문) [8] 웹지망생 16/09/01 00:20 716 1
    18323
    [본삭금]visual studio에서 eclipse 단축키 [3] 본인삭제금지 fsaas 16/08/31 23:53 594 0
    18322
    2038년 문제 [2] 민트색슈가♥ 16/08/31 21:37 616 1
    C) 알고리즘 문제 오답이 발생하는 이유가 뭘까요? (코드 김 주의) [3] 본인삭제금지 훗날닭집사장 16/08/31 21:23 496 0
    18320
    Window 프로그램 GUI 어떤식으로 개발하나요? [9] 쭁쭁 16/08/31 18:51 644 0
    18319
    [ASP] Session_End 시에 세션 사용여부?? [2] 본인삭제금지 릴라강 16/08/31 18:39 371 0
    [◀이전10개] [131] [132] [133] [134] [135] [136] [137] [138] [139] [140] [다음10개▶]
    단축키 운영진에게 바란다(삭제요청/제안) 운영게 게시판신청 자료창고 보류 개인정보취급방침 청소년보호정책 모바일홈