찾다
백엔드 개발PHP 튜토리얼비트별 AND 0보다 큰 조합의 최대 조합

Largest Combination With Bitwise AND Greater Than Zero

2275. 비트 단위 AND 0보다 큰 조합

난이도:

주제: 배열, 해시 테이블, 비트 조작, 계산

nums 배열의 비트 AND는 nums에 있는 모든 정수의 비트 AND입니다.

  • 예를 들어 nums = [1, 5, 3]의 경우 비트 AND는 1 & 5 & 3 = 1과 같습니다.
  • 또한 nums = [7]의 경우 비트 AND는 7입니다.

양의 정수 후보 배열이 제공됩니다. 모든 조합비트 AND를 평가합니다. 후보자의 각 번호는 각 조합에서 한 번만 사용할 수 있습니다.

비트 AND 0보다 후보 조합의 가장 큰

크기를 반환합니다.

예 1:

  • 입력:
  • 후보 = [16,17,71,62,12,24,14]
  • 출력:
  • 4
  • 설명:
      [16,17,62,24] 조합에는 16 & 17 & 62 & 24 = 16 >의 비트 AND가 있습니다. 0.
    • 조합의 크기는 4입니다.
    • 4보다 큰 크기의 조합에는 0보다 큰 비트 AND가 없음을 알 수 있습니다.
    • 둘 이상의 조합이 가장 큰 크기를 가질 수 있습니다.
    • 예를 들어 [62,12,24,14] 조합에는 62 & 12 & 24 & 14 = 8 >의 비트 AND가 있습니다. 0.

예 2:

  • 입력:
  • 후보 = [8,8]
  • 출력:
  • 2
  • 설명:
      가장 큰 조합 [8,8]은 8 & 8 = 8 >의 비트 AND를 갖습니다. 0.
    • 조합의 크기가 2이므로 2를 반환합니다.

제약조건:

  • 1 5
  • 1 7

힌트:

  1. 비트별 AND가 0보다 크려면 조합의 모든 숫자에 대해 적어도 하나의 비트가 1이어야 합니다.
  2. 후보의 길이는 24비트이므로 모든 비트 위치에 대해 비트별 AND가 해당 비트 위치에서 1을 갖도록 가장 큰 조합의 크기를 계산할 수 있습니다.

해결책:

조합의 모든 숫자에 걸쳐 이진 표현에서 하나 이상의 비트 위치가 설정(1)으로 유지되는 숫자 그룹을 식별하는 데 중점을 두어야 합니다.

솔루션 개요
  1. 비트 분석

    : 후보의 각 숫자는 최대 24비트의 이진수로 표현될 수 있으므로(1
  2. 각 위치에서 설정된 비트 계산: 각 비트 위치에 대해 해당 비트가 1로 설정된 후보의 숫자 수를 계산합니다. 여러 숫자가 동일한 위치에서 비트를 공유하는 경우 잠재적으로 해당 비트 위치에서 0보다 큰 비트 AND와 조합을 형성합니다.

  3. 가장 큰 수 찾기: 주어진 위치에 설정된 비트가 있는 가장 큰 숫자가 답이 될 것입니다. 이는 비트별 AND 결과가 다음보다 큰 가능한 가장 큰 조합을 나타내기 때문입니다. 제로.

후보 고려 = [16, 17, 71, 62, 12, 24, 14]:

  • 각 숫자를 바이너리로 변환하고 비트 위치를 분석합니다.
  • 모든 숫자에 걸쳐 각 비트가 몇 번이나 설정되었는지 계산합니다.
  • 모든 비트 위치에서 최대 개수를 찾습니다.

이 솔루션을 PHP: 2275로 구현해 보겠습니다. 비트 단위 AND 0보다 큰 조합의 최대 조합

<?php /**
 * @param Integer[] $candidates
 * @return Integer
 */
function largestCombination($candidates) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

// Example usage
$candidates = [16, 17, 71, 62, 12, 24, 14];
echo largestCombination($candidates); // Output: 4
?>

설명:

  1. 각 비트 위치를 통한 루프: 0부터 23까지 각 비트 위치를 반복합니다.
  2. 비트 세트가 있는 숫자 계산: 각 위치에 대해 특정 비트 세트가 있는 후보자의 숫자가 몇 개인지 계산합니다.
  3. 최대 조합 크기 업데이트: 모든 비트 위치에서 가장 높은 수를 추적합니다.
  4. 결과 반환: 결과는 필요에 따라 0보다 큰 비트 AND를 사용하여 가장 큰 조합 크기입니다.

복잡성 분석

  • 시간 복잡도: O(n x 24) = O(n), 여기서 n은 각 숫자에 대해 24개의 연산(각 비트 위치당 하나씩)을 수행하기 때문입니다.
  • 공간 복잡도: O(1), 고정된 양의 추가 공간만 사용하기 때문입니다.

이 접근 방식은 입력 크기 제한(candidates.length 5)을 처리하는 데 충분히 효율적입니다.

연락처 링크

이 시리즈가 도움이 되었다면 GitHub에서 저장소에 별표를 표시하거나 즐겨찾는 소셜 네트워크에서 게시물을 공유해 보세요. 여러분의 지원은 저에게 큰 의미가 될 것입니다!

이렇게 더 유용한 콘텐츠를 원하시면 저를 팔로우해주세요.

  • 링크드인
  • 깃허브

위 내용은 비트별 AND 0보다 큰 조합의 최대 조합의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
11 최고의 PHP URL 쇼트너 스크립트 (무료 및 프리미엄)11 최고의 PHP URL 쇼트너 스크립트 (무료 및 프리미엄)Mar 03, 2025 am 10:49 AM

종종 키워드와 추적 매개 변수로 혼란스러워하는 긴 URL은 방문자를 방해 할 수 있습니다. URL 단축 스크립트는 솔루션을 제공하여 소셜 미디어 및 기타 플랫폼에 이상적인 간결한 링크를 만듭니다. 이 스크립트는 개별 웹 사이트 a에 유용합니다

Instagram API 소개Instagram API 소개Mar 02, 2025 am 09:32 AM

Instagram은 2012 년 Facebook에서 유명한 인수에 이어 타사 사용을 위해 두 개의 API 세트를 채택했습니다. Instagram Graph API 및 Instagram Basic Display API입니다. 개발자는

Laravel의 플래시 세션 데이터로 작업합니다Laravel의 플래시 세션 데이터로 작업합니다Mar 12, 2025 pm 05:08 PM

Laravel은 직관적 인 플래시 방법을 사용하여 임시 세션 데이터 처리를 단순화합니다. 응용 프로그램에 간단한 메시지, 경고 또는 알림을 표시하는 데 적합합니다. 데이터는 기본적으로 후속 요청에만 지속됩니다. $ 요청-

Laravel Back End : Part 2, React가있는 React 앱 구축Laravel Back End : Part 2, React가있는 React 앱 구축Mar 04, 2025 am 09:33 AM

이것은 Laravel 백엔드가있는 React Application을 구축하는 데있어 시리즈의 두 번째이자 마지막 부분입니다. 이 시리즈의 첫 번째 부분에서는 기본 제품 목록 응용 프로그램을 위해 Laravel을 사용하여 편안한 API를 만들었습니다. 이 튜토리얼에서는 Dev가 될 것입니다

Laravel 테스트에서 단순화 된 HTTP 응답 조롱Laravel 테스트에서 단순화 된 HTTP 응답 조롱Mar 12, 2025 pm 05:09 PM

Laravel은 간결한 HTTP 응답 시뮬레이션 구문을 제공하여 HTTP 상호 작용 테스트를 단순화합니다. 이 접근법은 테스트 시뮬레이션을보다 직관적으로 만들면서 코드 중복성을 크게 줄입니다. 기본 구현은 다양한 응답 유형 단축키를 제공합니다. Illuminate \ support \ Facades \ http를 사용하십시오. http :: 가짜 ([ 'google.com'=> ​​'Hello World', 'github.com'=> ​​[ 'foo'=> 'bar'], 'forge.laravel.com'=>

PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법Mar 14, 2025 am 11:42 AM

PHP 클라이언트 URL (CURL) 확장자는 개발자를위한 강력한 도구이며 원격 서버 및 REST API와의 원활한 상호 작용을 가능하게합니다. PHP CURL은 존경받는 다중 프로모토콜 파일 전송 라이브러리 인 Libcurl을 활용하여 효율적인 execu를 용이하게합니다.

Codecanyon에서 12 개의 최고의 PHP 채팅 스크립트Codecanyon에서 12 개의 최고의 PHP 채팅 스크립트Mar 13, 2025 pm 12:08 PM

고객의 가장 긴급한 문제에 실시간 인스턴트 솔루션을 제공하고 싶습니까? 라이브 채팅을 통해 고객과 실시간 대화를 나누고 문제를 즉시 해결할 수 있습니다. 그것은 당신이 당신의 관습에 더 빠른 서비스를 제공 할 수 있도록합니다.

2025 PHP 상황 조사 발표2025 PHP 상황 조사 발표Mar 03, 2025 pm 04:20 PM

2025 PHP Landscape Survey는 현재 PHP 개발 동향을 조사합니다. 개발자와 비즈니스에 대한 통찰력을 제공하는 프레임 워크 사용, 배포 방법 및 과제를 탐색합니다. 이 조사는 현대 PHP Versio의 성장을 예상합니다

See all articles

핫 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를 무료로 생성하십시오.

뜨거운 도구

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.