2024年最全acm入门基础算法必看,2024年最新Android程序员架构之路该如何继续学习

最后,如果大伙有什么好的学习方法或建议欢迎大家在评论中积极留言哈,希望大家能够共同学习、共同努力、共同进步。

小编在这里祝小伙伴们在未来的日子里都可以 升职加薪,当上总经理,出任CEO,迎娶白富美,走上人生巅峰!!

不论遇到什么困难,都不应该成为我们放弃的理由!

很多人在刚接触这个行业的时候或者是在遇到瓶颈期的时候,总会遇到一些问题,比如学了一段时间感觉没有方向感,不知道该从那里入手去学习

如果你看到了这里,觉得文章写得不错就给个赞呗?如果你觉得那里值得改进的,请给我留言,一定会认真查询,修正不足,谢谢。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

高精度除法模板

给定两个非负整数A,B,请你计算 A / B的商和余数。

输入格式

共两行,第一行包含整数A,第二行包含整数B。

输出格式

共两行,第一行输出所求的商,第二行输出所求余数。

数据范围

1≤A的长度≤100000,

1≤B≤10000

B 一定不为0

输入样例:

7

2

输出样例:

3

1

#include

#include

#include

#include

using namespace std;

vector div(vector &A,int &b,int &r)

{

vector C;

r=0;

for(int i=A.size()-1;i>=0;–i)

{

r=r*10+A[i];

C.push_back(r/b);

r%=b;

}

reverse(C.begin(),C.end());

while(C.size()>1&&C.back()==0)

C.pop_back();

return C;

}

int main()

{

string a;

int b;

cin>>a>>b;

vector A;

for(int i=a.size()-1;i>=0;–i)

A.push_back(a[i]-‘0’);

int r;

auto B=div(A,b,r);

for(auto it=B.rbegin();it!=B.rend();++it)

printf(“%d”,*it);

cout<<endl<<r<<endl;

return 0;

}

一维前缀和模板

输入一个长度为n的整数序列。

接下来再输入m个询问,每个询问输入一对l, r。

对于每个询问,输出原序列中从第l个数到第r个数的和。

输入格式

第一行包含两个整数n和m。

第二行包含n个整数,表示整数数列。

接下来m行,每行包含两个整数l和r,表示一个询问的区间范围。

输出格式

共m行,每行输出一个询问的结果。

数据范围

1≤l≤r≤n1≤l≤r≤n,

1≤n,m≤1000001≤n,m≤100000,

−1000≤数列中元素的值≤1000−1000≤数列中元素的值≤1000

输入样例:

5 3

2 1 3 6 4

1 2

1 3

2 4

输出样例:

3

6

10

#include

#include

#include

#include

using namespace std;

const int cmax = 10e5 + 5;

int a[cmax], sum[cmax];

int main()

{

int n, m;

scanf(“%d%d”, &n, &m);

for (int i = 1; i <= n; i++)

scanf(“%d”, &a[i]);

for (int i = 1; i <= n; i++)

sum[i] = sum[i - 1] + a[i];

while (m–)

{

int l, r;

scanf(“%d%d”, &l, &r);

printf(“%d\n”, sum[r] - sum[l - 1]);

}

return 0;

}

二维前缀和模板

输入一个n行m列的整数矩阵,再输入q个询问,每个询问包含四个整数x1, y1, x2, y2,表示一个子矩阵的左上角坐标和右下角坐标。

对于每个询问输出子矩阵中所有数的和。

输入格式

第一行包含三个整数n,m,q。

接下来n行,每行包含m个整数,表示整数矩阵。

接下来q行,每行包含四个整数x1, y1, x2, y2,表示一组询问。

输出格式

共q行,每行输出一个询问的结果。

数据范围

1≤n,m≤10001≤n,m≤1000,

1≤q≤2000001≤q≤200000,

1≤x1≤x2≤n1≤x1≤x2≤n,

1≤y1≤y2≤m1≤y1≤y2≤m,

−1000≤矩阵内元素的值≤1000−1000≤矩阵内元素的值≤1000

输入样例:

3 4 3

1 7 2 4

3 6 2 8

2 1 2 3

1 1 2 2

2 1 3 4

1 3 3 4

输出样例:

17

27

21

#include

#include

#include

#include

using namespace std;

const int cmax = 1e3 + 5;

int a[cmax][cmax], sum[cmax][cmax];

int main()

{

int n, m, q;

scanf(“%d%d%d”, &n, &m, &q);

for (int i = 1; i <= n; i++)

{

for (int j = 1; j <= m; ++j)

{

scanf(“%d”, &a[i][j]);

sum[i][j] = sum[i - 1][j] + sum[i][j - 1] + a[i][j] - sum[i - 1][j - 1];

}

}

while (q–)

{

int x1, y1, x2, y2;

scanf(“%d%d%d%d”, &x1, &y1, &x2, &y2);

printf(“%d\n”, sum[x2][y2] - sum[x1 - 1][y2] - sum[x2][y1 - 1] + sum[x1 - 1][y1 - 1]);

}

return 0;

}

一维差分模板

输入一个长度为n的整数序列。

接下来输入m个操作,每个操作包含三个整数l, r, c,表示将序列中[l, r]之间的每个数加上c。

请你输出进行完所有操作后的序列。

输入格式

第一行包含两个整数n和m。

第二行包含n个整数,表示整数序列。

接下来m行,每行包含三个整数l,r,c,表示一个操作。

输出格式

共一行,包含n个整数,表示最终序列。

数据范围

1≤n,m≤1000001≤n,m≤100000,

1≤l≤r≤n1≤l≤r≤n,

−1000≤c≤1000−1000≤c≤1000,

−1000≤整数序列中元素的值≤1000−1000≤整数序列中元素的值≤1000

输入样例:

6 3

1 2 2 1 2 1

1 3 1

3 5 1

1 6 1

输出样例:

3 4 5 3 4 2

#include

#include

#include

#include

using namespace std;

const int cmax = 1e5 + 5;

int a[cmax], sum[cmax];

void insert(int l, int r, int val)

{

sum[l] += val;

sum[r + 1] -= val;

}

int main()

{

int n, m;

scanf(“%d%d”, &n, &m);

for (int i = 1; i <= n; i++)

scanf(“%d”, &a[i]);

for (int i = 1; i <= n; i++)

insert(i, i, a[i]);

while (m–)

{

int l, r, c;

scanf(“%d%d%d”, &l, &r, &c);

insert(l, r, c);

}

for (int i = 1; i <= n; i++)

sum[i] += sum[i - 1];

for (int i = 1; i <= n; i++)

printf("%d ", sum[i]);

return 0;

}

二维差分模板

输入一个n行m列的整数矩阵,再输入q个操作,每个操作包含五个整数x1, y1, x2, y2, c,其中(x1, y1)和(x2, y2)表示一个子矩阵的左上角坐标和右下角坐标。

每个操作都要将选中的子矩阵中的每个元素的值加上c。

请你将进行完所有操作后的矩阵输出。

输入格式

第一行包含整数n,m,q。

接下来n行,每行包含m个整数,表示整数矩阵。

接下来q行,每行包含5个整数x1, y1, x2, y2, c,表示一个操作。

输出格式

共 n 行,每行 m 个整数,表示所有操作进行完毕后的最终矩阵。

数据范围

1≤n,m≤10001≤n,m≤1000,

1≤q≤1000001≤q≤100000,

1≤x1≤x2≤n1≤x1≤x2≤n,

1≤y1≤y2≤m1≤y1≤y2≤m,

−1000≤c≤1000−1000≤c≤1000,

−1000≤矩阵内元素的值≤1000−1000≤矩阵内元素的值≤1000

输入样例:

3 4 3

1 2 2 1

3 2 2 1

1 1 1 1

1 1 2 2 1

1 3 2 3 2

3 1 3 4 1

输出样例:

2 3 4 1

4 3 4 1

2 2 2 2

#include

#include

#include

#include

using namespace std;

const int cmax=1e3+5;

int a[cmax][cmax],b[cmax][cmax];

void Differential (int x1,int y1,int x2,int y2,int c)

{

b[x1][y1]+=c;

b[x1][y2+1]-=c;

b[x2+1][y1]-=c;

b[x2+1][y2+1]+=c;

}

int main()

{

int n,m,q;

scanf(“%d%d%d”,&n,&m,&q);

for(int i=1; i<=n; i++)

for(int j=1; j<=m; j++)

scanf(“%d”,&a[i][j]);

for(int i=1; i<=n; i++)

for(int j=1; j<=m; j++)

Differential(i,j,i,j,a[i][j]);

while(q–)

{

int x1,x2,y1,y2,c;

scanf(“%d%d%d%d%d”,&x1,&y1,&x2,&y2,&c);

Differential(x1,y1,x2,y2,c);

}

for(int i=1;i<=n;i++)

for(int j=1;j<=m;j++)

b[i][j]+=b[i][j-1]+b[i-1][j]-b[i-1][j-1];

for(int i=1;i<=n;i++)

{

for(int j=1;j<=m;j++)

printf("%d ",b[i][j]);

printf(“\n”);

}

return 0;

}

双指针算法(求最长连续公共子序列)

给定一个长度为n的整数序列,请找出最长的不包含重复数字的连续区间,输出它的长度。

输入格式

第一行包含整数n。

第二行包含n个整数(均在0~100000范围内),表示整数序列。

输出格式

共一行,包含一个整数,表示最长的不包含重复数字的连续子序列的长度。

数据范围

1≤n≤1000001≤n≤100000

输入样例:

5

1 2 2 3 5

输出样例:

3

#include <bits/stdc++.h>

using namespace std;

const int cmax=1e6+5;

int a[cmax],s[cmax];

int main()

{

int n;

cin>>n;

for(int i=0;i<n;i++)

scanf(“%d”,&a[i]);

int res=0;

for(int i=0,j=0;i<n;++i)

{

s[a[i]]++;

while(s[a[i]]>1)

{

s[a[j]]–;

j++;

}

res=max(res,i-j+1);

}

printf(“%d\n”,res);

return 0;

}

位运算(lowbit算法)

给定一个长度为n的数列,请你求出数列中每个数的二进制表示中1的个数。

输入格式

第一行包含整数n。

第二行包含n个整数,表示整个数列。

输出格式

共一行,包含n个整数,其中的第 i 个数表示数列中的第 i 个数的二进制表示中1的个数。

数据范围

1≤n≤1000001≤n≤100000,

0≤数列中元素的值≤1090≤数列中元素的值≤109

输入样例:

5

1 2 3 4 5

输出样例:

1 1 2 1 2

写在最后

本次我的分享也接近尾声了,感谢你们在百忙中花上一下午来这里聆听我的宣讲,希望在接下来的日子,我们共同成长,一起进步!!!

最后放上一个大概的Android学习方向及思路(详细的内容太多了~),提供给大家:

对于程序员来说,要学习的知识内容、技术有太多太多,这里就先放上一部分,其他的内容有机会在后面的文章向大家呈现出来,不过我自己所有的学习资料都整理成了一个文档,一直在不断学习,希望能帮助到大家,也节省大家在网上搜索资料的时间来学习,也可以分享动态给身边好友一起学习!

为什么某些人会一直比你优秀,是因为他本身就很优秀还一直在持续努力变得更优秀,而你是不是还在满足于现状内心在窃喜!希望读到这的您能点个小赞和关注下我,以后还会更新技术干货,谢谢您的支持!

Android架构师之路很漫长,一起共勉吧!

如果你觉得文章写得不错就给个赞呗?如果你觉得那里值得改进的,请给我留言,一定会认真查询,修正不足,谢谢。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

格式

共一行,包含n个整数,其中的第 i 个数表示数列中的第 i 个数的二进制表示中1的个数。

数据范围

1≤n≤1000001≤n≤100000,

0≤数列中元素的值≤1090≤数列中元素的值≤109

输入样例:

5

1 2 3 4 5

输出样例:

1 1 2 1 2

写在最后

本次我的分享也接近尾声了,感谢你们在百忙中花上一下午来这里聆听我的宣讲,希望在接下来的日子,我们共同成长,一起进步!!!

最后放上一个大概的Android学习方向及思路(详细的内容太多了~),提供给大家:

[外链图片转存中…(img-bJA5oLn8-1715838105452)]

对于程序员来说,要学习的知识内容、技术有太多太多,这里就先放上一部分,其他的内容有机会在后面的文章向大家呈现出来,不过我自己所有的学习资料都整理成了一个文档,一直在不断学习,希望能帮助到大家,也节省大家在网上搜索资料的时间来学习,也可以分享动态给身边好友一起学习!

为什么某些人会一直比你优秀,是因为他本身就很优秀还一直在持续努力变得更优秀,而你是不是还在满足于现状内心在窃喜!希望读到这的您能点个小赞和关注下我,以后还会更新技术干货,谢谢您的支持!

Android架构师之路很漫长,一起共勉吧!

如果你觉得文章写得不错就给个赞呗?如果你觉得那里值得改进的,请给我留言,一定会认真查询,修正不足,谢谢。

[外链图片转存中…(img-qsEem2zV-1715838105453)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值