Heim >Backend-Entwicklung >C++ >Eins zu einer Zahl hinzufügen, die im C-Programm als Ziffernfeld dargestellt wird?

Eins zu einer Zahl hinzufügen, die im C-Programm als Ziffernfeld dargestellt wird?

PHPz
PHPznach vorne
2023-09-07 12:49:171070Durchsuche

Adding one to number represented as array of digits in C Program?

In diesem Abschnitt werden wir eine interessante Frage sehen. Angenommen, es wird eine Zahl angegeben. Wir müssen diese Zahl um 1 erhöhen. Dies ist eine sehr einfache Aufgabe. Aber hier werden wir die Zahlen als Array platzieren. Jede Ziffer der Zahl wird als Element des Arrays platziert. Wenn die Zahl 512 ist, wird sie als {5, 1, 2} gespeichert. Und wir müssen auch eine rekursive Methode verwenden, um die Zahl zu erhöhen. Schauen wir uns den Algorithmus an, um eine klare Vorstellung zu bekommen.

Algorithmus

inkrement(arr, n, index) −

Initially the default value of index is 0
begin
   if index < n, then
      if arr[index] < 9, then
         arr[index] := arr[index] + 1
      else
         arr[index] := 0
         increment(arr, n, index + 1)
   end if
   if index = n, then
      arr[n] := 1
      n := n + 1
   end if
end

Beispiel

#include <iostream>
#include <cmath>
#define MAX 20
using namespace std;
void increment(int num_arr[], int &n, int index = 0){
   if(index < n){
      if(num_arr[index] < 9){ //if digit is less than 9, add 1
         num_arr[index]++;
      }else{ //otherwise increase number recursively
         num_arr[index] = 0;
         increment(num_arr, n, index+1);
      }
   }
   if(index == n){
      num_arr[n] = 1; //add extra carry
      n++; //increase n
   }
}
void dispNumber(int num_arr[], int n){
   for(int i = n-1; i>= 0; i--){
      cout << num_arr[i];
   }  
   cout << endl;
}
int numToArr(int num_arr[], int number){
   int i = 0;
   int n = log10(number) + 1;
   for(int i = i; i< n; i++){
      num_arr[i] = number % 10;
      number /= 10;
   }
   return n;
}
main() {
   int number = 1782698599;
   int num_arr[MAX];
   int n = numToArr(num_arr, number);
   cout << "Initial Number: "; dispNumber(num_arr, n);
   increment(num_arr, n);
   cout << "Final Number: "; dispNumber(num_arr, n);
}

Ausgabe

Initial Number: 1782698599
Final Number: 1782698600

Das obige ist der detaillierte Inhalt vonEins zu einer Zahl hinzufügen, die im C-Programm als Ziffernfeld dargestellt wird?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:tutorialspoint.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen