목차
해결 방법을 찾는 방법
무차별 대입 방법
Example
Output
효율적인 방법
위 코드에 대한 설명
결론
백엔드 개발 C++ C++를 사용하여 L번째와 R번째 인덱스 사이에 설정된 비트만 있는 숫자 찾기

C++를 사용하여 L번째와 R번째 인덱스 사이에 설정된 비트만 있는 숫자 찾기

Aug 26, 2023 pm 09:45 PM
비트 연산 c 프로그래밍 디지털 상영

C++를 사용하여 L번째와 R번째 인덱스 사이에 설정된 비트만 있는 숫자 찾기

주어진 문제에서 우리는 주어진 범위 L, R 사이에 설정된 비트를 모두 포함하는 숫자의 값을 찾아야 합니다. 예를 들어 −

Input: L = 1, R = 5
Output: 62
Explanation: representation of given L and R in binary form is 0..0111110

Input: L = 1, R = 4
Output: 30
Explanation: representation of given L and R in binary form is 0..11110
로그인 후 복사

해결 방법을 찾는 방법

주어진 문제에서 우리는 무차별 대입 방법과 효율적인 방법이라는 두 가지 방법에 대해 논의할 것입니다.

무차별 대입 방법

이 방법에서는 주어진 범위를 반복하고 주어진 범위에서 2의 거듭제곱을 모두 더하면 이것이 답이 됩니다.

Example

#include<bits/stdc++.h>
using namespace std;
int main() {
   int L = 1, R = 3; // the given range
   int ans = 0; // our answer
   for(int i = L; i <= R; i++) // traversing through the whole range
      ans += pow(2, i); // adding values to the answer.
   cout << ans << "\n";
}
로그인 후 복사
로그인 후 복사

Output

14
로그인 후 복사
로그인 후 복사

이 방법에서는 범위를 반복하고 범위에 있는 숫자 중 2개의 거듭제곱을 더합니다. 이 프로그램의 시간 복잡도는 O(N)이며, 여기서 N은 범위의 크기입니다. 그러나 주어진 문제에 비트 지식을 적용함으로써 시간 복잡도를 더욱 향상시킬 수 있습니다.

효율적인 방법

이 방법에서는 간단히 답을 계산하는 공식을 구성합니다.

Example

#include<bits/stdc++.h>
using namespace std;
int main() {
   int L = 1, R = 3; // the given range
   int ans = 0; // our answer
   for(int i = L; i <= R; i++) // traversing through the whole range
      ans += pow(2, i); // adding values to the answer.
   cout << ans << "\n";
}
로그인 후 복사
로그인 후 복사

Output

14
로그인 후 복사
로그인 후 복사

이 방법에서는 답을 계산하는 공식을 공식화합니다.

위 코드에 대한 설명

아시다시피 주어진 범위에서 설정된 비트를 사용하여 숫자를 계산해야 하므로 이 방법에서는 모든 비트가 설정된 0에서 R까지의 숫자를 찾습니다. 그런 다음 모든 비트가 1에서 (L-1)로 설정된 숫자를 빼야 하므로 이 관찰을 공식화합니다. 주어진 코드의 전체 시간 복잡도는 O(1)입니다. 즉, 일정한 시간 복잡도입니다. 이는 일정한 시간에 어떤 답이라도 계산할 수 있음을 의미합니다.

결론

이 글에서는 "L번째와 R번째 인덱스 사이에 비트가 설정된 숫자만" 프로그램을 작성하겠습니다. 우리는 또한 이 문제를 해결하기 위해 C++ 프로그램과 완전한 방법(일반적이고 효율적인)을 배웠습니다. C, Java, Python 등과 같은 다른 언어로 동일한 프로그램을 작성할 수 있습니다. 이 기사가 도움이 되기를 바랍니다.

위 내용은 C++를 사용하여 L번째와 R번째 인덱스 사이에 설정된 비트만 있는 숫자 찾기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

Golang의 비트 연산(비트 연산자)에 대한 간략한 분석 Golang의 비트 연산(비트 연산자)에 대한 간략한 분석 Feb 24, 2023 pm 07:42 PM

컴퓨터 메모리가 비싸고 처리 능력이 제한되었던 옛날에는 해커 스타일의 비트 연산을 사용하여 정보를 처리하는 것이 선호되는 방법이었습니다(어떤 경우에는 유일한 방법이었습니다). 오늘날까지도 비트 연산의 직접적인 사용은 하위 수준 시스템 프로그래밍, 그래픽 처리, 암호화 등과 같은 많은 컴퓨팅 분야에서 여전히 필수적인 부분입니다.

C++를 사용하여 N번째 제곱수가 아닌 숫자를 찾는 코드를 작성하세요. C++를 사용하여 N번째 제곱수가 아닌 숫자를 찾는 코드를 작성하세요. Aug 30, 2023 pm 10:41 PM

우리 모두는 2, 3, 5, 7, 8 등과 같이 어떤 숫자의 제곱도 아닌 숫자를 알고 있습니다. N개의 정사각형이 아닌 숫자가 있으며 모든 숫자를 아는 것은 불가능합니다. 그래서 이 글에서는 제곱이 없는 숫자나 제곱이 아닌 숫자에 대한 모든 것과 C++에서 N번째 제곱이 아닌 숫자를 찾는 방법을 설명할 것입니다. N번째 비제곱수 어떤 숫자가 정수의 제곱인 경우, 그 숫자를 완전제곱수라고 합니다. 완전제곱수의 몇 가지 예는 다음과 같습니다. -1issquareof14issquareof29issquareof316issquareof425issquareof5 숫자가 정수의 제곱이 아닌 경우 해당 숫자를 제곱이 아닌 숫자라고 합니다. 예를 들어, 처음 15개의 정사각형이 아닌 숫자는 -2,3,5,6입니다.

C++를 사용하여 배열의 고유 쌍 수 찾기 C++를 사용하여 배열의 고유 쌍 수 찾기 Sep 07, 2023 am 11:53 AM

C++의 배열 구문에서 여러 개의 고유한 쌍을 생성하려면 적절한 지식이 필요합니다. 고유 쌍의 수를 찾는 동안 주어진 배열의 모든 고유 쌍을 계산합니다. 즉, 각 쌍이 고유해야 하는 모든 가능한 쌍이 형성될 수 있습니다. 예를 들어 -Input:array[]={5,5,9}Output:4Explanation:Thenumberoffalluniquepairsare(5,5),(5,9),(9,5)and(9,9).Input:array[] = {5,4,3,2,2} 출력: 해결 방법을 찾는 16가지 방법 이 문제를 해결하는 방법에는 두 가지가 있습니다.

C 프로그래밍에서 원의 넓이 구하기 C 프로그래밍에서 원의 넓이 구하기 Aug 25, 2023 pm 10:57 PM

원은 닫힌 그림입니다. 원의 모든 점은 원 내부의 점에서 등거리에 있습니다. 중심점을 원의 중심이라고 합니다. 한 점에서 원의 중심까지의 거리를 반지름이라고 합니다. 면적은 닫힌 그림의 크기 범위를 정량적으로 표현한 것입니다. 원의 면적은 원의 치수 내에 둘러싸인 면적입니다. 원의 면적을 계산하는 공식, Area=π*r*r 면적을 계산하기 위해 원의 반경을 입력으로 주고 공식을 사용하여 면적을 계산합니다. 알고리즘 STEP1: Takeradiusasinputfromtheuserusingstdinput.STEP2 : 원의 면적을 계산합니다. 면적=(

Java에서 BitSet 함수를 사용하여 비트 연산을 수행하는 방법 Java에서 BitSet 함수를 사용하여 비트 연산을 수행하는 방법 Jun 26, 2023 pm 06:11 PM

BitSet은 비트 작업에 사용되는 Java 클래스입니다. BitSet은 이진 비트로 구성된 배열로 생각할 수 있으며 각 이진 비트는 0 또는 1만 될 수 있습니다. BitSet은 설정, 지우기, 뒤집기, 가져오기 등을 포함하여 비트 작업을 수행하는 일련의 메서드를 제공합니다. BitSet을 사용하여 Java에서 비트 작업을 수행하는 것은 매우 간단합니다. 구체적인 작업 단계를 소개하겠습니다. 1. BitSet 개체를 만듭니다. BitSet 개체는 두 가지 방법으로 만들 수 있습니다. 1. 기본값을 사용하여 BitSet 개체를 만듭니다.

C++로 작성된 배열의 오른쪽 회전을 위한 반전 알고리즘 C++로 작성된 배열의 오른쪽 회전을 위한 반전 알고리즘 Sep 08, 2023 pm 08:17 PM

이 기사에서는 주어진 배열을 k 요소만큼 오른쪽으로 회전하는 반전 알고리즘에 대해 알아봅니다(예: −Input:arr[]={4,6,2,6,43,7,3,7}). k= 4 출력:{43,7,3,7,4,6,2,6}설명: 배열의 각 요소를 4개 요소별로 오른쪽으로 회전하면 {43,7,3,7,4,6,2,6}이 됩니다.입력:arr[]= {8 ,5,8,2,1,4,9,3},k=3출력:{4,9,3,8,5,8,2,1} 해결책 찾기

C++를 사용하여 최소값과 최대값이 동일한 하위 배열의 수를 찾는 코드를 작성하세요. C++를 사용하여 최소값과 최대값이 동일한 하위 배열의 수를 찾는 코드를 작성하세요. Aug 25, 2023 pm 11:33 PM

이번 글에서는 C++를 이용하여 최대값과 최소값이 같은 부분배열의 개수를 찾는 문제를 해결해보겠습니다. 다음은 문제의 예입니다. −Input:array={2,3,6,6,2,4,4,4}Output:12Explanation:{2},{3},{6},{6}, {2 },{4},{4},{4},{6,6},{4,4},{4,4}및{4,4,4}는 동일한 최대 및 최소 요소로 구성할 수 있는 하위 배열입니다.입력:배열={3, 3, 1,5,

C++를 사용하여 주어진 크기로 역방향 이중 연결 목록 그룹화 C++를 사용하여 주어진 크기로 역방향 이중 연결 목록 그룹화 Sep 04, 2023 am 09:49 AM

이 문제에서는 연결 리스트의 헤드에 대한 포인터와 정수 k가 제공됩니다. 크기가 k인 그룹에서는 연결된 목록을 뒤집어야 합니다. 예를 들어 -Input:1<->2<->3<->4<->5(이중 링크 목록),k=3Output:3<->2<->1<->5<->4 솔루션 찾기 방법 이 문제에서는 이 문제를 해결하기 위한 재귀 알고리즘을 공식화합니다. 이 방법에서는 재귀를 사용하고 재귀를 사용하여 문제를 해결합니다. 예#include<iostream&

See all articles