Usa l'operatore Modulo in C++
- 
          
            Usa l’operatore %per calcolare il resto nella divisione
- 
          
            Usa l’operatore %per generare numeri interi casuali inferiori a un dato numero massimo in C++
- 
          
            Usa oggetti funzione definiti dalla libreria per sostituire l’operatore %in C++
 
Questo articolo introdurrà come utilizzare l’operatore modulo in C++.
Usa l’operatore % per calcolare il resto nella divisione
    
La caratteristica standard dell’operatore modulo (%) è calcolare il resto di una divisione. Il valore di ritorno dell’istruzione - x % y rappresenta il resto a sinistra dopo che x è diviso per y. L’operatore modulo è definito in modo che entrambi gli operandi devono essere numeri interi e un divisore è diverso da zero. L’esempio seguente mostra l’operatore modulo utilizzato con diverse coppie di interi con segno. Nota che, per stampare il carattere % sulla console usando la funzione printf, dovremmo usare %%.
#include <iostream>
#include <vector>
using std::cin;
using std::cout;
using std::endl;
using std::vector;
int main() {
  vector<int> ivec1{24, 24, -24, -24, 24};
  vector<int> ivec2{7, 8, -8, -7, -6};
  for (size_t i = 0; i < ivec1.size(); ++i) {
    printf("% -d %% % -d = % -d\n", ivec1[i], ivec2[i], ivec1[i] % ivec2[i]);
  }
  cout << endl;
  return EXIT_SUCCESS;
}
Produzione:
 24 %  7 =  3
 24 %  8 =  0
-24 % -8 =  0
-24 % -7 = -3
 24 % -6 =  0
Usa l’operatore % per generare numeri interi casuali inferiori a un dato numero massimo in C++
L’utilizzo alternativo dell’operatore modulo consiste nel controllare il generatore di numeri casuali per fornire solo numeri inferiori a un numero intero specifico. Un programmatore è responsabile della scelta del toolkit per la generazione di numeri casuali a seconda della necessità di qualità della casualità, ma entrambi i metodi possono essere combinati con % per specificare il limite superiore dei numeri generati. In questo caso, utilizziamo la funzione rand, il cui valore di ritorno è accoppiato con il valore massimo desiderato utilizzando l’operatore modulo.
#include <ctime>
#include <iostream>
#include <vector>
using std::cin;
using std::cout;
using std::endl;
using std::vector;
constexpr int MAX = 1000;
constexpr int NUMS_TO_GENERATE = 10;
int main() {
  vector<int> ivec1{24, 24, -24, -24, 24};
  vector<int> ivec2{7, 8, -8, -7, -6};
  std::srand(std::time(nullptr));
  for (int i = 0; i < NUMS_TO_GENERATE; i++) {
    cout << rand() % MAX << "; ";
  }
  cout << endl;
  cout << endl;
  return EXIT_SUCCESS;
}
Produzione:
98; 194; 398; 190; 782; 550; 404; 557; 509; 945;
Usa oggetti funzione definiti dalla libreria per sostituire l’operatore % in C++
La libreria standard C++ definisce più classi che rappresentano operatori aritmetici, relazionali e logici tradizionali. Questi sono chiamati oggetti funzione e hanno nomi come std::plus<Type>, std::modulus<Type> e così via. Type specifica il tipo di parametro dell’operatore di chiamata. Il seguente esempio di codice mostra l’oggetto funzione std::modulo utilizzato su vettori di numeri interi.
#include <ctime>
#include <iostream>
#include <vector>
using std::cin;
using std::cout;
using std::endl;
using std::vector;
int main() {
  vector<int> ivec1{24, 24, -24, -24, 24};
  vector<int> ivec2{7, 8, -8, -7, -6};
  std::modulus<> intMod;
  int mod_of_nums = intMod(ivec1[1], ivec2[1]);
  printf("%d %% %d = %d\n", ivec1[1], ivec2[1], mod_of_nums);
  return EXIT_SUCCESS;
}
Produzione:
24 % 8 = 0
Founder of DelftStack.com. Jinku has worked in the robotics and automotive industries for over 8 years. He sharpened his coding skills when he needed to do the automatic testing, data collection from remote servers and report creation from the endurance test. He is from an electrical/electronics engineering background but has expanded his interest to embedded electronics, embedded programming and front-/back-end programming.
LinkedIn Facebook