"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 사례 연구: 가중 9개 꼬리 문제

사례 연구: 가중 9개 꼬리 문제

2024-11-08에 게시됨
검색:251

가중 9개의 꼬리 문제는 가중 최단 경로 문제로 축소될 수 있습니다.
섹션에서는 9개의 꼬리 문제를 제시하고 이를 BFS 알고리즘을 사용하여 해결했습니다. 이 섹션에서는 문제의 변형을 제시하고 최단 경로 알고리즘을 사용하여 문제를 해결합니다.

9개의 꼬리 문제는 모든 동전이 아래로 향하게 하는 최소 이동 횟수를 찾는 것입니다. 각 움직임은 선두 동전과 그 이웃 동전을 뒤집습니다. 가중 9개 꼬리 문제는 뒤집기 횟수를 각 동작의 가중치로 지정합니다. 예를 들어, 첫 번째 행의 첫 번째 동전과 두 이웃 동전을 뒤집어 아래 그림 a의 동전을 아래 그림 b의 동전으로 변경할 수 있습니다. 따라서 이 이동의 가중치는 3입니다. 중앙 동전과 네 개의 이웃 동전을 뒤집어 아래 그림 c의 동전을 아래 그림 d로 변경할 수 있습니다. 따라서 이 이동의 가중치는 5.

입니다.

Case Study: The Weighted Nine Tails Problem

가중 9개 꼬리 문제는 간선 가중치 그래프에서 시작 노드에서 대상 노드까지의 최단 경로를 찾는 것으로 축소될 수 있습니다. 그래프에는 512개의 노드가 있습니다. 노드 u에서 노드 v로 이동하는 경우 노드 v에서 u로 간선을 생성합니다. 뒤집기 횟수를 가장자리의 가중치로 지정합니다.

섹션에서 9개의 꼬리 문제를 모델링하기 위해 NineTailModel 클래스를 정의했음을 기억하세요. 이제 아래 그림과 같이 NineTailModel을 확장하는 WeightedNineTailModel이라는 새 클래스를 정의합니다.

Case Study: The Weighted Nine Tails Problem

NineTailModel 클래스는 그래프를 생성하고 대상 노드 511에 뿌리를 둔 트리를 얻습니다. WeightedNineTailModelWeightedGraph를 생성하고 대상 노드 511[에 뿌리를 둔 ShortestPathTree를 얻는다는 점을 제외하면 NineTailModel와 동일합니다. &&&]. WeightedNineTailModelNineTailModel을 확장합니다. getEdges() 메소드는 그래프의 모든 간선을 찾습니다. getNumberOfFlips(int u, int v) 메소드는 노드 u에서 노드 v로 뒤집힌 횟수를 반환합니다. getNumberOfFlips(int u) 메소드는 노드 u에서 대상 노드까지 뒤집힌 횟수를 반환합니다.

아래 코드는

WeightedNineTailModel.를 구현합니다.

패키지 데모; import java.util.*; 공개 클래스 WeightedNineTailModel은 NineTailModel을 확장합니다. /** 모델 구성 */ 공개 WeightedNineTailModel() { // 가장자리 생성 List 가장자리 = getEdges(); // 그래프 생성 WeightedGraph 그래프 = 새로운 WeightedGraph(가장자리, NUMBER_OF_NODES); // 대상 노드에 루트가 있는 최단 경로 트리를 얻습니다. 트리 = graph.getShortestPath(511); } /** 그래프의 모든 간선 생성 */ 개인 목록 getEdges() { // 가장자리 저장 List 가장자리 = new ArrayList(); for(int u = 0; u .ShortestPathTree)tree).getCost(u); } }
package demo;
import java.util.*;

public class WeightedNineTailModel extends NineTailModel {
    /** Construct a model */
    public WeightedNineTailModel() {
        // Create edges
        List edges = getEdges();

        // Create a graph
        WeightedGraph graph = new WeightedGraph(edges, NUMBER_OF_NODES);

        // Obtain a shortest path tree rooted at the target node
        tree = graph.getShortestPath(511);
    }

    /** Create all edges for the graph */
    private List getEdges() {
        // Store edges
        List edges = new ArrayList();

        for(int u = 0; u .ShortestPathTree)tree).getCost(u);
    }
}

WeightedNineTailModelNineTailModel을 확장하여 가중치 9개 꼬리 문제를 모델링하는 WeightedGraph를 구축합니다(라인 10-11). 각 노드 u에 대해 getEdges() 메서드는 뒤집힌 노드 v를 찾고 뒤집힌 횟수를 가장자리의 가중치로 할당합니다(v, u) (라인 30). getNumberOfFlips(int u, int v) 메소드는 노드 u에서 노드 v(38-47행)까지 뒤집힌 횟수를 반환합니다. 뒤집기 횟수는 사이에 있는 서로 다른 셀의 수입니다. 노드 2개(라인 44).

WeightedNineTailModel는 대상 노드 511에 뿌리를 둔 ShortestPathTree를 얻습니다(라인 14). treeNineTailModel에 정의된 보호된 데이터 필드이고 ShortestPathTreeTree의 하위 클래스입니다. NineTailModel에 정의된 메서드는 트리 속성을 사용합니다.

getNumberOfFlips(int u) 메소드(49-52행)는 노드 u에서 대상 노드까지의 뒤집기 횟수를 반환합니다. 이는 노드에서 경로 비용입니다. u를 대상 노드로 이동합니다. 이 비용은 ShortestPathTree 클래스(51행)에 정의된 getCost(u) 메소드를 호출하여 얻을 수 있습니다. 아래 코드는 사용자에게 초기 노드를 입력하라는 메시지를 표시하고 대상 노드에 도달하기 위한 최소 뒤집기 횟수를 표시하는 프로그램을 제공합니다.


패키지 데모; java.util.Scanner 가져오기; 공개 클래스 WeightedNineTail { 공개 정적 무효 메인(String[] args) { // 사용자에게 9개의 코인의 H와 T를 입력하라는 메시지를 표시합니다. System.out.print("처음 9개의 동전 H와 T를 입력하세요: "); 스캐너 입력 = new Scanner(System.in); 문자열 s = input.nextLine(); char[]initialNode = s.toCharArray(); WeightedNineTailModel 모델 = new WeightedNineTailModel(); java.util.List 경로 = model.getShortestPath(NineTailModel.getIndex(initialNode)); System.out.println("동전을 뒤집는 단계는 다음과 같습니다. "); for (int i = 0; i

package demo;

import java.util.Scanner;

public class WeightedNineTail {

    public static void main(String[] args) {
        // Prompt the user to enter nine coins' Hs and Ts
        System.out.print("Enter the initial nine coins Hs and Ts: ");
        Scanner input = new Scanner(System.in);
        String s = input.nextLine();
        char[] initialNode = s.toCharArray();

        WeightedNineTailModel model = new WeightedNineTailModel();
        java.util.List path = model.getShortestPath(NineTailModel.getIndex(initialNode));

        System.out.println("The steps to flip the coins are ");
        for (int i = 0; i 

동전을 뒤집는 단계는 다음과 같습니다.

큭큭

TTTT

ㅋㅋㅋ

큭큭

THT

TTTT

TT

TTTT

TTTT

뒤집기 횟수는 8입니다.

프로그램은 사용자에게 8행의 문자열로

H

T의 조합을 사용하여 9개의 문자로 된 초기 노드를 입력하라는 메시지를 표시하고 다음에서 문자 배열을 얻습니다. 문자열(9행), 모델 생성(11행), 초기 노드에서 대상 노드까지의 최단 경로 획득(12~13행), 경로에 노드를 표시(16~17행)하고 [를 호출합니다. &&&]getNumberOfFlips 대상 노드에 도달하는 데 필요한 뒤집기 횟수를 가져옵니다(라인 20).

릴리스 선언문 이 글은 https://dev.to/paulike/case-study-the-weighted-nine-tails-problem-3n9i?1에서 복제됩니다.1 침해 내용이 있는 경우, [email protected]으로 연락하여 삭제하시기 바랍니다.
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3