BRONZE
BRONZE 등급의 판매자 자료

송홍엽 데이터 구조 프로젝트 파일( sparse matrix의 transpose, Max subsequence sum 4가지 알고리즘, List bucket sorting )

13 페이지
한컴오피스
최초등록일 2012.07.23 최종저작일 2011.04
13P 미리보기
송홍엽 데이터 구조 프로젝트 파일( sparse matrix의 transpose, Max subsequence sum 4가지 알고리즘, List bucket sorting )
  • 미리보기

    소개

    sparse matrix의 transpose를 구하는 프로그램,
    Max subsequence sum( 랜덤으로 숫자를 발생시켜 연속된 배열에 입력하고 가장 합이 커지는 합을 구하는 것)
    을 4가지 서로 다른 알고리즘을 통해 구하고 각각의 알고리즘에서 걸리를 시간을 측정함, List에 여러가지 숫자를 입력시키고, bucket sorting을 함, 그리고 중복된 숫자를 삭제하여 같은 숫자를 한번씩 입력하게 함.

    목차

    (Ⅰ) 강의자료

    (1) 문제 접근 방법
    (2) 세부적 풀이
    (3) 소스 분석
    (4) 결과 분석
    (Ⅱ) 문제

    (1) 문제 접근 방법
    (2) 세부적 풀이
    (3) 소스 분석
    (4)결과 분석

    (Ⅲ) 게시판의 data1.txt 와 data2.txt를 이용하여 다음을 수행하시오.

    (1) 문제 접근 방법
    (2) 세부적 풀이
    (3) 소스 분석
    (4) 결과 분석

    본문내용

    (Ⅰ) 강의자료
    1. 문제
    sparse matrix의 transpose를 구하는 프로그램 작성 및 수행.

    (1) 문제 접근 방법
    matrix의 transpose를 구하는 것이기 때문에 언뜻 보면 단순히 matrix를 변수로 하고 이 matrix의 원소를 입력하여 transpose를 구하는 프로그램을 짤 수 있지만, sparse matrix는 특히 원소에 0이 많은 matrix를 말한다. 따라서 matrix를 통째로 변수로 하는 것은 데이터가 들어가는 용량을 낭비하는 결과를 초래할 수 있다. 그래서 이 matrix의 원소들을 하나의 array로 하고 이 어레이는 각각 원소, 원소의 행과 열을 포함하는 구조체로 만들기로 했다.

    <중 략>

    (2) 세부적 풀이
    이를 위해 4가지 알고리즘을 생각해야 하는데 그 알고리즘은 다음과 같다.
    ①알고리즘1
    알고리즘 1에서 a[500]에 rand 함수로 데이터를 넣는다. 연속된 숫자들의 합을 계산하기 위해 합을 재시 시작할 시작점 i와 끝점 j를 정할 것이다. for문 두개를 가지고 sum이라는 변수에 숫자들을 더해 나간다. for문이 끝나고 만들어진 sum과 그 이전과 비교해 만들어진 Maxsum을 비교해 가장 큰 Maxsum을 찾는다.
    ②알고리즘2
    알고리즘 1에서는 시작점을 정하고 마지막 점을 정하여 그 사이의 원소들을 모두 더하였다. 하지만 이 경우 시작점이 같은 sum들에서 같은 계산이 중복된다. 알고리즘2에서는 이렇게 중복되는 계산들없이 시작점에서 출발하는 i가 증가함에 따라 바로 sum이 나온다. 중복되는 계산을 줄여서 알고리즘 2는 알고리즘 1보다 상대적으로 빠르다.

    <중 략>

    start= clock();
    for(i = 0;i<100; i++) algorithm3();
    end = clock();
    printf("알고리듬3을 돌린시간은 %f입니다\n\n", (double)(end-start)/CLOCKS_PER_SEC);

    start= clock();
    for(i = 0;i<100; i++) algorithm4();
    end = clock();
    printf("알고리듬4을 돌린시간은 %f입니다\n\n", (double)(end-start)/CLOCKS_PER_SEC);

    참고자료

    · 없음
  • 자료후기

    Ai 리뷰
    지식판매자의 해당 자료는 과제를 작성하는 데 큰 도움이 되었고, 내용이 풍부하여 많은 정보를 얻을 수 있었습니다. 정말 추천할 만한 자료입니다.
    • 자주묻는질문의 답변을 확인해 주세요

      해피캠퍼스 FAQ 더보기

      꼭 알아주세요

      • 자료의 정보 및 내용의 진실성에 대하여 해피캠퍼스는 보증하지 않으며, 해당 정보 및 게시물 저작권과 기타 법적 책임은 자료 등록자에게 있습니다.
        자료 및 게시물 내용의 불법적 이용, 무단 전재∙배포는 금지되어 있습니다.
        저작권침해, 명예훼손 등 분쟁 요소 발견 시 고객센터의 저작권침해 신고센터를 이용해 주시기 바랍니다.
      • 해피캠퍼스는 구매자와 판매자 모두가 만족하는 서비스가 되도록 노력하고 있으며, 아래의 4가지 자료환불 조건을 꼭 확인해주시기 바랍니다.
        파일오류 중복자료 저작권 없음 설명과 실제 내용 불일치
        파일의 다운로드가 제대로 되지 않거나 파일형식에 맞는 프로그램으로 정상 작동하지 않는 경우 다른 자료와 70% 이상 내용이 일치하는 경우 (중복임을 확인할 수 있는 근거 필요함) 인터넷의 다른 사이트, 연구기관, 학교, 서적 등의 자료를 도용한 경우 자료의 설명과 실제 자료의 내용이 일치하지 않는 경우
    문서 초안을 생성해주는 EasyAI
    안녕하세요. 해피캠퍼스의 방대한 자료 중에서 선별하여 당신만의 초안을 만들어주는 EasyAI 입니다.
    저는 아래와 같이 작업을 도와드립니다.
    - 주제만 입력하면 목차부터 본문내용까지 자동 생성해 드립니다.
    - 장문의 콘텐츠를 쉽고 빠르게 작성해 드립니다.
    - 스토어에서 무료 캐시를 계정별로 1회 발급 받을 수 있습니다. 지금 바로 체험해 보세요!
    이런 주제들을 입력해 보세요.
    - 유아에게 적합한 문학작품의 기준과 특성
    - 한국인의 가치관 중에서 정신적 가치관을 이루는 것들을 문화적 문법으로 정리하고, 현대한국사회에서 일어나는 사건과 사고를 비교하여 자신의 의견으로 기술하세요
    - 작별인사 독후감
    해캠 AI 챗봇과 대화하기
    챗봇으로 간편하게 상담해보세요.
    2025년 06월 07일 토요일
    AI 챗봇
    안녕하세요. 해피캠퍼스 AI 챗봇입니다. 무엇이 궁금하신가요?
    8:52 오후