123th LeetCode Weekly Contest Add to Array-Form of Integer
For a non-negative integer X
, the array-form of X
is an array of its digits in left to right order. For example, if X = 1231
, then the array form is [1,2,3,1]
.
Given the array-form A
of a non-negative integer X
, return the array-form of the integer X+K
.
Example 1:
Input: A = [1,2,0,0], K = 34
Output: [1,2,3,4]
Explanation: 1200 + 34 = 1234
Example 2:
Input: A = [2,7,4], K = 181
Output: [4,5,5]
Explanation: 274 + 181 = 455
Example 3:
Input: A = [2,1,5], K = 806
Output: [1,0,2,1]
Explanation: 215 + 806 = 1021
Example 4:
Input: A = [9,9,9,9,9,9,9,9,9,9], K = 1
Output: [1,0,0,0,0,0,0,0,0,0,0]
Explanation: 9999999999 + 1 = 10000000000
Note:
1 <= A.length <= 10000
0 <= A[i] <= 9
0 <= K <= 10000
- If
A.length > 1
, thenA[0] != 0
这题肯定有简单解法,写大数加法只是更熟练而已
class Solution { public: vector<int> addToArrayForm(vector<int>& A, int K) { int len = A.size(); int num=0; vector<int>Ve; int a[11000]={0},b[11000]={0},c[11000]={0}; for(int i=len-1;i>=0;i--){ a[num++]=A[i]; //cout<<A[i]<<endl; } int cnt=0; int i; while(K){ b[cnt++]=K%10; K/=10; } //cout<<"B"<<endl; int k=max(len,cnt); for(i=0;i<k;i++) { //cout<<a[i]<<" "<<b[i]<<endl; c[i]=a[i]+b[i]; } for(i=0; i<k; i++){ //cout<<"A1"<<endl; if(c[i]>=10){ c[i+1]+=c[i]/10; c[i]%=10; } //cout<<"A2"<<endl; } if(c[k]==0) k--; for(i=k;i>=0;i--){ Ve.push_back(c[i]); } return Ve; } };
分类:
LeetCode
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~