여기에서 우리는 다른 영역에서 우리를 도울 수 있는 C++ 프로그래밍 언어의 몇 가지 좋은 트릭을 볼 것입니다. 경쟁적인 프로그래밍 이벤트에 참여하려는 경우 이러한 트릭을 사용하면 코드 작성 시간을 줄이는 데 도움이 됩니다. 이러한 예를 하나씩 살펴보겠습니다.
-
% 연산자를 사용하지 않고 숫자가 홀수인지 짝수인지 확인합니다. 이 트릭은 간단합니다. 숫자와 1로 비트 AND 연산을 수행할 수 있습니다. 결과가 0이 아니면 홀수이고 그렇지 않으면 짝수입니다. 논리가 너무 간단합니다. 모든 홀수는 LSb에서 1을 갖습니다. 따라서 AND를 1로 수행한 후 원하는 결과를 쉽게 얻을 수 있도록 LSb를 제외한 모든 문자를 마스크합니다.
if ((n & 1) != 0) { //this is odd } else { //This is even }
-
시프트 연산자를 사용하여 빠르게 곱하고 나눕니다. 숫자를 2n과 같은 숫자로 곱하려면 숫자를 왼쪽으로 n번 쉬프트하면 됩니다. 마찬가지로 숫자를 2n으로 나누려면 숫자를 오른쪽으로 n번 이동합니다.
x = 40; y = x << 2; //x will be multiplied with 4, so y = 160 cout << x; x = 40; y = x >> 2; //x will be divided by 4, so y = 10 cout << x;
-
세 번째 변수를 사용하지 않고 두 숫자를 바꿀 수 있습니다. 이것은 + 및 - 연산자를 사용하여 수행할 수 있습니다. 그러나 비트 XOR 연산자를 사용하여 수행할 수도 있습니다. 번호를 수동으로 확인하여 확인할 수 있습니다.
//swap x and y x ^= y; y ^= x; x ^= y;
-
때로는 코드에서 strlen() 함수를 사용할 수 없다는 몇 가지 제약이 있습니다. 이 경우 우리는 우리 자신의 strlen() 함수를 만듭니다. 케이스가 문자에만 액세스하는 경우에는 실제로 이 작업을 수행할 필요가 없습니다. i 위치의 문자가 유효한지(0이 아닌) 확인할 수 있습니다. 이것이 0이 아니면 횡단할 수 있고 그렇지 않으면 중지합니다.
for(int i = 0; s[i]; i++){ cout << s[i]; }
-
가장 자주 우리는 STL에서 push_back() 함수를 사용하여 vector 등과 같은 일부 컨테이너에 새 요소를 추가합니다. 이를 사용하지 않고 emplace_back()도 사용할 수 있습니다. 이 기능은 훨씬 빠릅니다. 이것은 다른 곳에 메모리를 할당하지 않고 컨테이너에 할당된 메모리를 추가합니다.
-
C++는 내장된 GCD 기능을 제공합니다. 다른 경우에 사용할 수 있습니다. 구문은 아래와 같습니다.
__gcd(x, y) //find GCD of x and y
-
main 함수에서 배열의 최대 크기는 10^6 정도입니다. 그러나 배열이 전역적으로 선언되면 최대 10^7까지 크기를 선언할 수 있습니다.
-
로그 연산을 사용하여 모든 숫자의 최상위 자릿수를 계산할 수 있습니다. 아이디어를 얻으려면 다음 논리를 참조하십시오.
n = 4578; double k = log10(n); k = k – floor(k); int x = pow(10, k); //x is the most significant digit
-
로그 연산을 사용하여 자릿수를 직접 계산합니다. 이를 위해 루프를 사용하지 않습니다.
n = 4578; int digit_count = floot(log10(n)) + 1
-
이 논리를 사용하여 숫자가 2의 거듭제곱인지 직접 확인할 수 있습니다.
x = 1024; bool check = x && (!(x & (x-1))); //if this is true, then power of two.
-
다음 조건을 확인할 수 있는 일부 내장 알고리즘이 C++에 있습니다.
all_of(left, left + n, isPositive()); //check all are positive or not any_of(left, left + n, isPositive()); //check at least one positive or not. none_of(left, left + n, isPositive()); //check no elements are positive
-
한 컨테이너에서 다른 컨테이너로 요소를 복사하는 복사 기능.
int src[5] = {10, 20, 30, 40, 50}; int des[5]; copy_n(src, 5, dest);
-
itoa()라는 알고리즘이 있습니다. 이 알고리즘은 초기값을 *first에 할당한 다음 사후 증가 연산자를 사용하여 값을 사용하는 것처럼 순차적으로 증가하는 값의 범위를 만드는 데 사용할 수 있습니다.
int arr[5] = {0}; char str[5] = {0}; itoa(arr, arr+5, 15); //it will generate {15, 16, 17, 18, 19} itoa(str, str+5, ‘A’); //it will generate {‘A’, ‘B’, ‘C’, ‘D’, ‘E’}
-
바이너리 형식으로 값을 할당합니다. 0b 접두사를 이진수와 함께 사용하여 해당 숫자가 이진수로 제공됨을 나타낼 수 있습니다.
int x = 0b1101; //then x will hold 13
-
C++에서는 조건 연산자를 사용하지 않고 키워드를 사용할 수 있습니다. '&' 대신 like 키워드 'and'를 사용할 수 있습니다.
x = 10; if(x < 10 and x > 5) cout << “True” << endl; else cout << “False” << endl; //This will return True