如何将一个表示为链表的数字加 1?


我们在这里将看到如何对存储于链表中的数字加 1。在链表中,将存储数字的每个数字。比如:如果数字为 512,则将存储为以下形式 −

512 = (5)-->(1)-->(2)-->NULL

我们提供列表传入增量函数。该函数将在对该数字加 1 后,返回另一个列表。我们在这里使用 C++ STL 链表。我们来看看算法,以获得更好的想法。

算法

incrementList(l1)

Begin
   carry := 1
   res := an empty list
   for each node n from l1, scan from last to first, do
      item := (l1.item + carry) mod 10
      insert item at the beginning of res
      carry := (l1.item + carry) / 10
   done
   if carry is not 0, then
      add carry at the beginning of res
   end if
   return res
End

示例

#include<iostream>
#include<list>
using namespace std;
list<int> incListNum(list<int> l1){
   list<int>::reverse_iterator it1 = l1.rbegin();
   list<int> result;
   int carry = 1; //this 1 will be added
   while(it1 != l1.rend()){
      result.push_front((*it1 + carry) % 10);
      carry = (*it1 + carry) / 10;
      it1++;
   }
   if(carry != 0){
      result.push_front(carry);
   }
   return result;
}
list<int> numToList(int n){
   list<int> numList;
   while(n != 0){
      numList.push_front(n % 10);
      n /= 10;
   }
   return numList;
}
void displayListNum(list<int> numList){
   for(list<int>::iterator it = numList.begin(); it != numList.end();
   it++){
      cout<<*it;
   }
   cout << endl;
}
int main() {
   int n1 = 9999;
   list<int> n1_list = numToList(n1);
   list<int> res = incListNum(n1_list);
   cout << "The number: "; displayListNum(n1_list);
   cout << "Result: "; displayListNum(res);
}

输出

The number: 9999
Result: 10000

更新时间:31-Jul-2019

143 次浏览

开启你的职业

通过完成课程获取认证

立即开始
广告