Given a non-negative number represented as an array of digits, plus one to the number.
The digits are stored such that the most significant digit is at the head of the list
这道题的题目意思花了好长时间才能明白。明白了之后还好,感觉还可以做一做。
值得注意的一点是当结果位数需要增大的时候需要为vector增大空间。这个需要用到vector中的insert。这个还是头一次用到,感觉不错。
代码奉上:
class Solution { public: vector<int> plusOne(vector<int> &digits) { int value=digits.size()-1;//设置长度 while(value>=0) { if(digits[value]<9) { digits[value]+=1; break; } else { digits[value]=0; value--; } } value++; if(value==0&&digits[value]==0) { digits.insert(digits.begin(),1);//这句话十分关键 } return digits; } };