G 점수를 달성하는 데 필요한 최소 점수를 알아내는 C++ 프로그램
두 개의 배열 p와 c가 있고 각 배열에는 D 요소가 있고 또 다른 숫자 G가 있다고 가정합니다. 프로그래밍 대회에서 각 질문은 난이도에 따라 점수가 매겨진다고 생각해 보세요. 질문 p[i]의 점수는 100i입니다. 이러한 p[1] + ... + p[D] 문제는 모두 경쟁에서 발생하는 문제입니다. 프로그래밍 웹사이트의 사용자는 숫자로 된 total_score를 가지고 있습니다. 사용자의 total_score는 다음 두 요소의 합입니다.
기본 점수: 해결한 모든 문제의 점수 합
Reward: 사용자가 100i 점수로 모든 문제를 풀면 기본 점수에 더해 완벽한 보상 c[ i]를 얻게 됩니다.
Amal은 대회에 처음 참가했으며 아직 어떤 문제도 해결하지 못했습니다. 그의 목표는 종합 G학점 이상을 받는 것이다. 그가 이 목표를 달성하려면 최소한 얼마나 많은 문제를 해결해야 하는지 알아내야 한다.
입력이 G = 500; P = [3, 5]; C = [500, 800]이면 출력은 3
Steps
이 문제를 해결하기 위해 다음 단계를 따릅니다.
D := size of p mi := 10000 for initialize i := 0, when i < 1 << D, update (increase i by 1), do: sum := 0 count := 0 at := 0 an array to store 10 bits b, initialize from bit value of i for initialize j := 0, when j < D, update (increase j by 1), do: if jth bit in b is 1, then: count := p[j] sum := sum + ((j + 1) * 100 * p[j] + c[j] Otherwise at := j if sum < G, then: d := (G - sum + (at + 1) * 100 - 1) / ((at + 1) * 100) if d <= p[at], then: sum := sum + (at + 1) count := count + d if sum >= G, then: mi := minimum of mi and count return mi
예
더 나은 이해를 위해 아래 구현을 살펴보겠습니다. −
#include <bits/stdc++.h> using namespace std; int solve(int G, vector<int> p, vector<int> c){ int D = p.size(); int mi = 10000; for (int i = 0; i < 1 << D; i++){ int sum = 0; int count = 0; int at = 0; bitset<10> b(i); for (int j = 0; j < D; j++){ if (b.test(j)){ count += p.at(j); sum += (j + 1) * 100 * p.at(j) + c.at(j); } else { at = j; } } if (sum < G){ int d = (G - sum + (at + 1) * 100 - 1) / ((at + 1) * 100); if (d <= p.at(at)){ sum += (at + 1) * 100 * d; count += d; } } if (sum >= G) { mi = min(mi, count); } } return mi; } int main() { int G = 500; vector<int> P = { 3, 5 }; vector<int> C = { 500, 800 }; cout << solve(G, P, C) << endl; }
Input
500, { 3, 5 }, { 500, 800 }
Output
3
위 내용은 G 점수를 달성하는 데 필요한 최소 점수를 알아내는 C++ 프로그램의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제









아래에는 로마 숫자를 십진수로 변환하는 C 언어 알고리즘이 나와 있습니다. 알고리즘 1단계 - 시작 2단계 - 런타임에 로마 숫자 읽기 3단계 - 길이: = strlen(roman) 4단계 - i=0에서 길이-1까지 단계 4.1-switch(roman[i]) 4.1.1단계-case'm': &nbs

사전식 문자열 비교는 문자열이 사전 순서로 비교된다는 것을 의미합니다. 예를 들어 'apple'과 'appeal'이라는 두 개의 문자열이 있는 경우 'app'의 처음 세 문자가 동일하므로 첫 번째 문자열이 마지막에 옵니다. 그러면 첫 번째 문자열의 문자는 'l'이고 두 번째 문자열의 네 번째 문자는 'e'입니다. 'e'는 'l'보다 짧기 때문에 사전순으로 정렬하면 e가 먼저 나옵니다. 문자열은 정렬되기 전에 사전순으로 비교됩니다. 이 기사에서는 C++를 사용하여 두 문자열을 사전순으로 비교하는 다양한 기술을 살펴보겠습니다. C++ 문자열에서 Compare() 함수 사용하기 C++string 개체에는 Compare() 함수가 있습니다.

Yanyu Jianghu에는 일종의 하우스 게임플레이가 있으며, 플레이어는 자유롭게 집을 지을 수 있으며, 집을 성공적으로 지으면 동시에 게임 내 하우스 점수도 부여됩니다. 물론 계산 방법도 주어진 계산 방법을 사용하여 계산되며 플레이어가 살펴볼 수 있습니다. Yanyujianghu의 하우스 점수 계산 방법 1. 하우스 점수: 외모 점수, 배치 점수, 규모 점수, 연구는 네 부분으로 나누어집니다. 2. 외모 점수: 주로 건물 스킨 보너스 포인트와 이동 보너스 포인트(200점)가 있습니다. 건물 스킨은 2가지가 있는데, 하나는 위의 홈샵에서 교환하는 핸드패치이고, 다른 하나는 턴테이블에 있는 스킨패치입니다. 3. 배치 포인트 : 제작한 가구로 얻는 포인트, 녹색 상한선은 입니다. 10점, 파란색 상한은 15점, 보라색 상한은 10점입니다.

쌍곡선 함수는 원 대신 쌍곡선을 사용하여 정의되며 일반 삼각 함수와 동일합니다. 제공된 각도(라디안)에서 쌍곡사인 함수의 비율 매개변수를 반환합니다. 그러나 반대로 하십시오. 즉, 반대로 하십시오. 쌍곡선 사인으로부터 각도를 계산하려면 쌍곡선 역사인 연산과 같은 역쌍곡선 삼각법 연산이 필요합니다. 이 과정에서는 라디안 단위의 쌍곡선 사인 값을 사용하여 각도를 계산하기 위해 C++에서 쌍곡선 역사인(asinh) 함수를 사용하는 방법을 보여줍니다. 쌍곡선 아크사인 연산은 다음 공식 -$$\mathrm{sinh^{-1}x\:=\:In(x\:+\:\sqrt{x^2\:+\:1})}을 따릅니다. 여기서\:In\:은\:자연 로그\:(log_e\:k)

연결된 목록은 동적 메모리 할당을 사용합니다. 즉, 그에 따라 메모리가 늘어나고 줄어듭니다. 이는 노드 모음으로 정의됩니다. 여기서 노드는 데이터와 링크라는 두 부분으로 구성됩니다. 데이터, 링크, 연결리스트는 다음과 같이 표현됩니다. - 연결리스트의 종류 연결리스트에는 다음과 같은 4가지 종류가 있습니다. - 단일 연결리스트 / 단일 연결리스트 이중 / 이중 연결리스트 원형 단일 연결리스트 순환 이중 연결리스트 연결된 목록의 길이를 찾는 재귀 메서드 논리는 -intlength(node *temp){ if(temp==NULL) returnl{&n;

맵은 각 요소가 두 값, 즉 키 값과 맵 값의 쌍인 C++의 특수한 유형의 컨테이너입니다. 키 값은 각 항목을 인덱싱하는 데 사용되며 매핑된 값은 키와 연결된 값입니다. 매핑된 값이 고유한지 여부에 관계없이 키는 항상 고유합니다. C++에서 맵 요소를 인쇄하려면 반복자를 사용해야 합니다. 항목 집합의 요소는 반복자 개체로 표시됩니다. 반복자는 주로 배열 및 기타 유형의 컨테이너(예: 벡터)와 함께 사용되며 특정 범위 내의 특정 요소를 식별하는 데 사용할 수 있는 특정 작업 집합을 가지고 있습니다. 반복자는 범위나 컨테이너에 있는 다양한 요소를 참조하기 위해 증가하거나 감소할 수 있습니다. 반복자는 범위에 있는 특정 요소의 메모리 위치를 가리킵니다. 반복자를 사용하여 C++에서 지도 인쇄하기 먼저, 정의하는 방법을 살펴보겠습니다.

Word에 분수를 삽입하는 방법을 모르는 사람들이 많을 수 있습니다. 결국 우리는 분수를 입력하는 상황을 자주 접하지 않습니다. 하지만 이런 경우가 발생하면 더 번거로울 수 있으므로 Word 점수를 입력하는 방법을 이해해야 합니다. Word에서 분수를 입력하는 방법은 실제로 매우 간단합니다. 다음으로 Word에서 분수를 입력하는 방법을 공유하겠습니다. Word에서 분수를 입력하는 방법에는 여러 가지가 있으며 그 중 하나는 수식 삽입 기능을 사용하는 것입니다. 방법은 다음과 같습니다. Word 문서를 연 후, 메뉴 바에서 [삽입] 옵션을 클릭하고, 팝업 메뉴에서 [수식]을 선택하세요. 그러면 원하는 분수를 입력할 수 있는 수식 편집기가 열립니다. 편집기에서 분수 형식 버튼을 사용하여 분수를 만들거나 수동으로 "\frac{numerator}{

이름 바꾸기 기능은 파일이나 디렉토리를 이전 이름에서 새 이름으로 변경합니다. 이 작업은 이동 작업과 유사합니다. 따라서 이 이름 바꾸기 기능을 사용하여 파일을 이동할 수도 있습니다. 이 함수는 stdio.h 라이브러리 헤더 파일에 있습니다. rename 함수의 구문은 다음과 같습니다. intrename(constchar*oldname,constchar*newname); rename() 함수의 함수는 두 개의 매개변수를 허용합니다. 하나는 oldname이고 다른 하나는 newname입니다. 두 매개변수는 모두 파일의 이전 이름과 새 이름을 정의하는 상수 문자에 대한 포인터입니다. 파일 이름이 성공적으로 변경되면 0을 반환하고, 그렇지 않으면 0이 아닌 정수를 반환합니다. 이름 바꾸기 작업 중
