当前位置: 首页 > news >正文

《算法竞赛进阶指南》0x51 线性DP

0x51 线性DP

271. 杨老师的照相排列

题意:

NNN 个人站成左端对齐的 kkk 排,每排有 NiN_iNi 人,Ni>NjN_i > N_jNi>Nj 如果 i<ji < ji<j,则 Ni>NjN_i > N_jNi>Nj 。每一排从左到右身高递减,每一列从后到前身高递减。询问方案数。

解析:

按照身高从大到小的顺序决定位置。在任意时刻,已经确定位置的人在每一行中一定是从左开始的连续位置。

kkk 元组可以描述当前已经确定的位置。在决定当前人的位置时,可放的排为没放满的排,且放完后满足 ni>nj(i<j)n_i > n_j (i < j)ni>nj(i<j)nin_ini 为第 iii 排已经放的人数。

代码:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef double db;
#define fi first
#define se second
const int maxn = 32;
const int INF = 0x3f3f3f3f;
typedef pair<int, int> pii;int n[6];
int k; 
ll dp[maxn][maxn][maxn][maxn][maxn];
int check(int a, int b, int c, int d, int e){return a >= b && b >= c && c >= d && d >= e && e >= 0;
}
void solve(){memset(dp, 0, sizeof(dp));dp[0][0][0][0][0] = 1;for(int a = 0; a <= n[1]; a++){for(int b = 0; b <= n[2]; b++){for(int c = 0; c <= n[3]; c++){for(int d = 0; d <= n[4]; d++){for(int e = 0; e <= n[5]; e++){if(!check(a, b, c, d, e))continue;if(check(a-1, b, c, d, e))dp[a][b][c][d][e] += dp[a-1][b][c][d][e];if(check(a, b-1, c, d, e))dp[a][b][c][d][e] += dp[a][b-1][c][d][e];if(check(a, b, c-1, d, e))dp[a][b][c][d][e] += dp[a][b][c-1][d][e];if(check(a, b, c, d-1, e))dp[a][b][c][d][e] += dp[a][b][c][d-1][e];if(check(a, b, c, d, e-1))dp[a][b][c][d][e] += dp[a][b][c][d][e-1];}}}}}//cout << "ans = ";cout << dp[n[1]][n[2]][n[3]][n[4]][n[5]] << endl;
}
int main(){ios::sync_with_stdio(false);cin.tie(0); cout.tie(0);while(1){cin >> k;if(k == 0)break;memset(n, 0, sizeof(n));for(int i = 1; i <= k; i++)cin >> n[i];solve();}return 0;
}


最长公共上升子序列

题意:

给定两个序列 a,ba, ba,b,询问最长公共上升子序列的长度

解析:

fi,jf_{i,j}fi,j 为在 aaa 的前 iii 个数和 bbb 的前 jjj 个数中以 bjb_jbj 的最长公共上升子序列的长度。

  • 不选 aia_iaifi,j=fi−1,jf_{i,j} = f_{i-1, j}fi,j=fi1,j
  • 选了 aia_iaifi,j=max⁡bk<bj{fi−1,k+1}f_{i,j} = \max\limits_{b_k<b_j}\{f_{i-1,k}+1\}fi,j=bk<bjmax{fi1,k+1}

此时时间复杂度为 O(n3)O(n^3)O(n3)

容易发现每次都是从 ai>bka_i > b_kai>bk 的前缀最大值转移过来,增加一个变量记录 fi−1,kf_{i-1,k}fi1,k 的前缀最大值。此时时间复杂度为 O(n2)O(n^2)O(n2)

代码:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef double db;
#define fi first
#define se second
const int maxn = 3e3+10;
const int INF = 0x3f3f3f3f;
typedef pair<int, int> pii;int n, a[maxn], b[maxn];
int f[maxn][maxn], ans;
int main(){ios::sync_with_stdio(false);cin.tie(0); cout.tie(0);cin >> n;for(int i = 1; i <= n; i++)cin >> a[i];for(int i = 1; i <= n; i++)cin >> b[i];for(int i = 1; i <= n; i++){int maxx = 0;for(int j = 1; j <= n; j++){f[i][j] = f[i-1][j];if(a[i] == b[j])f[i][j] = max(f[i][j], maxx+1);else if(a[i] > b[j])maxx = max(maxx, f[i][j]);if(i == n)ans = max(ans, f[i][j]);}}cout << ans << endl;return 0;
}


分级

题意:

给定序列 AAA,构造非严格的单调序列 BBB,使 S=∑i=1n∣Ai−Bi∣S = \sum\limits_{i=1}\limits^n |A_i-B_i|S=i=1nAiBi 最小。询问最小值。

解析

结论: 一定存在一组最优解,使得每个 BiB_iBi 都存在 jjj,满足 Bi=AjB_i = A_jBi=Aj

fi,jf_{i,j}fi,j 为确定前 iii 数,且第 iii 个数为 CjC_jCjCCC 为升序排序后的 AAA 序列。
fi,j=min⁡k<=j{fi−1,k+∣Cj−Ai∣}f_{i,j} = \min\limits_{k <= j}\{ f_{i-1,k} + |C_j-A_i|\}fi,j=k<=jmin{fi1,k+CjAi}维护前缀最小值,可在 O(1)O(1)O(1) 时间转移

代码:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef double db;
#define fi first
#define se second
const int maxn = 2e3+10;
const int INF = 0x3f3f3f3f;
typedef pair<int, int> pii;int n, a[maxn], c[maxn];
int ans = INF;
bool cmp(int a, int b){return a > b;
}
int f[maxn][maxn];
void solve(){memset(f, 0, sizeof(f));int res = INF;	for(int i = 1; i <= n; i++){int minn = INF;for(int j = 1; j <= n; j++){minn = min(minn, f[i-1][j]);f[i][j] = minn + abs(a[i]-c[j]);}}for(int i = 1; i <= n; i++)res = min(res, f[n][i]);ans = min(ans, res);
}
int main(){ios::sync_with_stdio(false);cin.tie(0); cout.tie(0);cin >> n;for(int i = 1; i <= n; i++){cin >> a[i];c[i] = a[i];}sort(c+1, c+1+n);solve();sort(c+1, c+1+n, cmp);solve();cout << ans << endl;return 0;
}


移动服务

题意:

有 3 个人。有 nnn 个请求一个人去某地,移动有代价。依次满足请求,询问最小代价。

题意:

fi,x,yf_{i, x, y}fi,x,y 表示满足前 iii 个请求后,三人位于 posi,x,ypos_i, x, yposi,x,y 时的最小代价。

每个状态可以转移到另外三个状态,见代码。

代码:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef double db;
#define fi first
#define se second
const int maxn = 1e3+10;
const int INF = 0x3f3f3f3f;
typedef pair<int, int> pii;int L, n;
int p[maxn], c[210][210];
int dp[maxn][210][210];
int main(){ios::sync_with_stdio(false);cin.tie(0); cout.tie(0);cin >> L >> n;	for(int i = 1; i <= L; i++)for(int j = 1; j <= L; j++)cin >> c[i][j];for(int i = 1; i <= n; i++)cin >> p[i];memset(dp, INF, sizeof(dp));dp[0][1][2] = 0; p[0] = 3;for(int i = 0; i < n; i++){for(int x = 1; x <= L; x++){for(int y = 1; y <= L; y++){if(x == y || y == p[i] || x == p[i])continue;int u = p[i+1];dp[i+1][x][y] = min(dp[i+1][x][y], dp[i][x][y] + c[p[i]][u]);dp[i+1][x][p[i]] = min(dp[i+1][x][p[i]], dp[i][x][y] + c[y][u]);dp[i+1][p[i]][y] = min(dp[i+1][p[i]][y], dp[i][x][y] + c[x][u]);}}}int res = INF;for(int i = 1; i <= L; i++)for(int j = 1; j <= L; j++)res = min(res, dp[n][i][j]);cout << res << endl;return 0;
}


传纸条

题意:

m×nm\times nm×n 的矩阵,每次可以向右或者向下走一步。从左上角都右下角选择两条互不相交(在路径端点可以相交)的路径,使点权和最大。

解析:

fi,j,x,yf_{i,j,x,y}fi,j,x,y 为第一条路径走到 (i,j)(i,j)(i,j) 且第二条路径走到 (x,y)(x,y)(x,y) 的最大点权和

对于 (i,j)=(x,y)(i,j) = (x,y)(i,j)=(x,y) 的状态,只计算一次点权

也可以网络流。

把每个点拆成入点和出点,入点向出点连边,容量1,费用为点权。

每个点的出点向能到达的点的入点连边,容量INF,费用 0;再连一条边,容量INF,费用 0.

源点向起点的入点连边,容量2,费用 0;终点的出点向汇点连边,容量2,费用 0 。

参考洛谷上 Duan2baka 大佬题解

代码:

#include<iostream>
#include<algorithm>
using namespace std;
int dp[55][55][55][55],a[55][55],n,m;
int main(){cin >> m >> n;for(int i = 1; i <= m; i++){for(int j = 1; j <= n; j++)cin >> a[i][j];}for (int i = 1; i <= m; i++)for (int j = 1; j <= n; j++)for (int k = 1; k <= m; k++)for (int l = 1; l <= n; l++) {dp[i][j][k][l]=max(max(dp[i-1][j][k-1][l],dp[i-1][j][k][l-1]),max(dp[i][j-1][k-1][l],dp[i][j-1][k][l-1]))+a[i][j]+a[k][l];if(i==k && j==l) dp[i][j][k][l] -= a[i][j];}cout << dp[m][n][m][n];
}


饼干

题意:

mmm 个饼干,分给 nnn 个人。每个人有参数 gig_igi,如果有 aia_iai 个人的饼干多于 iii ,则 iii 产生 ai×gia_i \times g_iai×gi 的怨气。

每个孩子最少分一个饼干,询问最少的怨气。

解析:

贪心的考虑,ggg 大的人一定分的多于 ggg 少的人。否则可以交换,结果不会变劣。

fi,jf_{i,j}fi,j 为前 iii 个孩子分了 jjj 个饼干的最小怨气和。

如果当前第 iii 个人的饼干数大于 1,则前 iii 个人饼干数都大于 1。每个人都减去一个饼干,aaa 不变,所以 fi,j=fi,j−if_{i,j} = f_{i,j-i}fi,j=fi,ji

如果当前第 iii 个人的饼干数为1,枚举有多少人饼干数不为 1

fi,j=min⁡0≤k<i{fk,j−i+k+k∑t=k+1igt}f_{i,j} = \min\limits_{0\le k<i}\{f_{k,j-i+k}+k\sum\limits_{t = k+1}\limits^ig_t\}fi,j=0k<imin{fk,ji+k+kt=k+1igt}

时间复杂度为 O(n3m)O(n^3m)O(n3m)。也可以前缀和优化一下,时间复杂度变成 O(n2m)O(n^2m)O(n2m)

代码:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef double db;
#define fi first
#define se second
#define mkp(a, b) make_pair((a), (b))
const int maxn = 3e2+10;
const int maxm = 5e3+10;
const int INF = 0x3f3f3f3f;
typedef pair<int, int> pii;struct node{int g, id;node(){}node(int g, int id) : g(g), id(id){}bool operator < (const node &b) const{return g > b.g;}
}s[maxn];
int g[maxn], sum[maxn];
int f[maxn][maxm];
pii fr[maxn][maxm];
int res[maxn];
void cal(int x, int y){if(x == 0)return;cal(fr[x][y].first, fr[x][y].second);if(fr[x][y].first == x){for(int i = 1; i <= x; i++)res[s[i].id]++;}else{for(int i = fr[x][y].first+1; i <= x; i++)res[s[i].id] = 1;}
}
int n, m;
int main(){ios::sync_with_stdio(false);cin.tie(0); cout.tie(0);cin >> n >> m;for(int i = 1; i <= n; i++){cin >> s[i].g;s[i].id = i;}		sort(s+1, s+1+n);for(int i = 1; i <= n; i++)sum[i] = sum[i-1] + s[i].g;memset(f, INF, sizeof(f));f[0][0] = 0;for(int i = 1; i <= n; i++){for(int j = i; j <= m; j++){f[i][j] = f[i][j-i];fr[i][j] = mkp(i, j-i);for(int k = 0; k < i; k++){if(f[i][j] > f[k][j-i+k] + k*(sum[i]-sum[k])){f[i][j] = f[k][j-i+k] + k*(sum[i]-sum[k]);fr[i][j] = mkp(k, j-i+k);}}}}cout << f[n][m] << endl;cal(n, m);for(int i = 1; i <= n; i++)cout << res[i] << " ";cout << endl;return 0;
}

相关文章:

《算法竞赛进阶指南》0x51 线性DP

0x51 线性DP 271. 杨老师的照相排列 题意&#xff1a; NNN 个人站成左端对齐的 kkk 排&#xff0c;每排有 NiN_iNi​ 人&#xff0c;Ni>NjN_i > N_jNi​>Nj​ 如果 i<ji < ji<j&#xff0c;则 Ni>NjN_i > N_jNi​>Nj​ 。每一排从左到右身高递减&…...

spring数据库事务管理

1.什么是事务 事务是逻辑上的一组操作&#xff0c;要么都执行&#xff0c;要么都不执行。 需要注意的是&#xff1a;事务能否生效数据库引擎是否支持事务是关键。比如常用的 MySQL 数据库默认使用支持事务的 innodb引擎。但是&#xff0c;如果把数据库引擎变为 myisam&#x…...

Huggingface微调BART的代码示例:WMT16数据集训练新的标记进行翻译

BART模型是用来预训练seq-to-seq模型的降噪自动编码器&#xff08;autoencoder&#xff09;。它是一个序列到序列的模型&#xff0c;具有对损坏文本的双向编码器和一个从左到右的自回归解码器&#xff0c;所以它可以完美的执行翻译任务。 如果你想在翻译任务上测试一个新的体系…...

synchronized 的 monitor 机制

synchronized 的 monitor 机制 前言 本文基于 jdk 8 编写。author JellyfishMIX - github / blog.jellyfishmix.comLICENSE GPL-2.0 monitor monitor 是 synchronized 中用以实现线程之间的互斥与协作的主要手段&#xff0c;它可以看成是对象或者 class 持有的锁。每一个对象…...

NumPy 初学者指南中文第三版:1~5

原文&#xff1a;NumPy: Beginner’s Guide - Third Edition 协议&#xff1a;CC BY-NC-SA 4.0 译者&#xff1a;飞龙 一、NumPy 快速入门 让我们开始吧。 我们将在不同的操作系统上安装 NumPy 和相关软件&#xff0c;并看一些使用 NumPy 的简单代码。 本章简要介绍了 IPython…...

ChatGLM-6B论文代码笔记

ChatGLM-6B 文章目录 ChatGLM-6B前言一、原理1.1 优势1.2 实验1.3 特点&#xff1a;1.4 相关知识点 二、实验2.1 环境基础2.2 构建环境2.3 安装依赖2.4 运行2.5 数据2.6 构建前端页面 3 总结 前言 Github&#xff1a;https://github.com/THUDM/ChatGLM-6B 参考链接&#xff1a…...

机器学习入门实例-加州房价预测-1(数据准备与可视化)

问题描述 数据来源&#xff1a;California Housing Prices dataset from the StatLib repository&#xff0c;1990年加州的统计数据。 要求&#xff1a;预测任意一个街区的房价中位数 缩小问题&#xff1a;superwised multiple regressiong(用到人口、收入等特征) univariat…...

【ROS2指南-20】了解ROS2组件的用法

在单个进程中组合多个节点 目录 背景 运行演示 发现可用组件 使用 ROS 服务 (1.) 与发布者和订阅者的运行时组合 使用 ROS 服务 (1.) 与服务器和客户端的运行时组合 使用 ROS 服务的编译时组合 (2.) 使用 dlopen 的运行时组合 使用启动动作组合 高级主题 卸载组件 重新…...

使用AI进行“文本纠错”

AI在现实中的应用有很多&#xff0c;你有没有想过&#xff0c;它还可以进行文本纠错呢&#xff1f;传统的校对既耗时又枯燥&#xff0c;通过“AI纠错”&#xff0c;不仅能更快完成&#xff0c;还能提高准确度。那么AI“文本纠错”背后的原理是什么呢&#xff1f;和我一起看看吧…...

第九章 法律责任与法律制裁

第九章 法律责任与法律制裁_副本 目录 第一节 法律责任的概念 一 法律责任的含义二 法律责任的特点 第二节 法律责任的分类与竞合 一 法律责任的分类 &#xff08;一&#xff09;根据责任行为所违反的法律的性质 民事责任&#xff1a;刑事责任行政责任违宪责任 &#xff08;二…...

如何选择好用的海康视频恢复软件?综合考虑这几点

海康视频恢复通常是指从海康威视监控设备中恢复删除或丢失的视频。在使用海康设备进行监控时&#xff0c;一些重要的视频可能会被误删除或其他原因导致丢失&#xff0c;如果没有及时备份&#xff0c;数据就可能会“永久”丢失&#xff1f;其实不然&#xff0c;我们可以选择好用…...

前端学习:HTML颜色(什么是RGB、HEX、HSL)

一、什么是RGB、HEX、HSL&#xff1f; 无论是RGB、HEX、HSL&#xff0c;它们的作用只有一个&#xff1a;用数字表达出一种颜色。 1.RGB RGB通过输入的数值&#xff0c;将红色、绿色和蓝色的光源以一定的量混合在一起&#xff0c;形成颜色。 软件中通常让你输入Red、Green、B…...

zookeeper + kafka集群搭建详解

目录 1.消息队列介绍 1.为什么需要消息队列 &#xff08;MO&#xff09; 2.使用消息队列的好处 3.消息队列的两种模式 2.Kafka相关介绍 1.Kafka定义 2.Kafka简介 3. Kafka的特性 3.Kafka系统架构 1. Broker&#xff08;服务器&#xff09; 2. Topic&#xff08;一个队…...

【数据结构与算法】 - 双向链表 - 详细实现思路及代码

目录 一、概述 二、双向链表 三、双向链表实现步骤  &#x1f4cc;3.1 C语言定义双向链表结点  &#x1f4cc;3.2 双向链表初始化  &#x1f4cc;3.3 双向链表插入数据  &#x1f4cc;3.4 双向链表删除数据  &#x1f4cc;3.5 双向链表查找数据  &#x1f4cc;3.6 双向链…...

面试官在线点评4份留学生简历! 这些坑你中了几个?如何写项目描述才能被大厂发面试?转专业简历该咋写 | 还有优秀简历展示!

我们给大家展示一下 从材料的准备 也就是说到底包含哪些具体的项目 为什么说这些项目是不错的 第二呢就是说在陈述上 在整个这个简历的结构 他的完备性他的准确性 他的正确性 以及最后他的具体的这种项目的描述 那讲完了这个好的简历呢 我们另外搜集了几份简历 那这些简历呢其实…...

一觉醒后ChatGPT 被淘汰了

OpenAI 的 Andrej Karpathy 都大力宣传&#xff0c;认为 AutoGPT 是 prompt 工程的下一个前沿。 近日&#xff0c;AI 界貌似出现了一种新的趋势&#xff1a;自主人工智能。 这不是空穴来风&#xff0c;最近一个名为 AutoGPT 的研究开始走进大众视野。特斯拉前 AI 总监、刚刚回归…...

spring框架的事务

1.什么是事务? 事务&#xff1a;是数据库操作的最小工作单元&#xff0c;是作为单个逻辑工作单元执行的一系列操作&#xff1b;这些操作作为一个整体一起向系统提交&#xff0c;要么都执行、要么都不执行&#xff1b;事务是一组不可再分割的操作集合&#xff08;工作逻辑单元…...

Spring配置数据源

Spring配置数据源数据源的作用环境准备手动创建c3p0数据源封装抽取关键信息&#xff0c;手动创建c3p0数据源使用Spring容器配置数据源数据源的作用 数据源(连接池)是提高程序性能如出现的 事先实例化数据源&#xff0c;初始化部分连接资源 使用连接资源时从数据源中获取 使用完…...

【前端之旅】Vue入门笔记

一名软件工程专业学生的前端之旅,记录自己对三件套(HTML、CSS、JavaScript)、Jquery、Ajax、Axios、Bootstrap、Node.js、Vue、小程序开发(Uniapp)以及各种UI组件库、前端框架的学习。 【前端之旅】Web基础与开发工具 【前端之旅】手把手教你安装VS Code并附上超实用插件…...

WPF教程(二)--Application WPF程序启动方式

1.Application介绍 WPF与WinForm一样有一个 Application对象来进行一些全局的行为和操作&#xff0c;并且每个 Domain &#xff08;应用程序域&#xff09;中仅且只有一个 Application 实例存在。和 WinForm 不同的是WPF Application默认由两部分组成 : App.xaml 和 App.xaml.…...

线程与协程

1. 线程与协程 1.1. “函数调用级别”的切换、上下文切换 1. 函数调用级别的切换 “函数调用级别的切换”是指&#xff1a;像函数调用/返回一样轻量地完成任务切换。 举例说明&#xff1a; 当你在程序中写一个函数调用&#xff1a; funcA() 然后 funcA 执行完后返回&…...

STM32F4基本定时器使用和原理详解

STM32F4基本定时器使用和原理详解 前言如何确定定时器挂载在哪条时钟线上配置及使用方法参数配置PrescalerCounter ModeCounter Periodauto-reload preloadTrigger Event Selection 中断配置生成的代码及使用方法初始化代码基本定时器触发DCA或者ADC的代码讲解中断代码定时启动…...

[ICLR 2022]How Much Can CLIP Benefit Vision-and-Language Tasks?

论文网址&#xff1a;pdf 英文是纯手打的&#xff01;论文原文的summarizing and paraphrasing。可能会出现难以避免的拼写错误和语法错误&#xff0c;若有发现欢迎评论指正&#xff01;文章偏向于笔记&#xff0c;谨慎食用 目录 1. 心得 2. 论文逐段精读 2.1. Abstract 2…...

【快手拥抱开源】通过快手团队开源的 KwaiCoder-AutoThink-preview 解锁大语言模型的潜力

引言&#xff1a; 在人工智能快速发展的浪潮中&#xff0c;快手Kwaipilot团队推出的 KwaiCoder-AutoThink-preview 具有里程碑意义——这是首个公开的AutoThink大语言模型&#xff08;LLM&#xff09;。该模型代表着该领域的重大突破&#xff0c;通过独特方式融合思考与非思考…...

vue3 字体颜色设置的多种方式

在Vue 3中设置字体颜色可以通过多种方式实现&#xff0c;这取决于你是想在组件内部直接设置&#xff0c;还是在CSS/SCSS/LESS等样式文件中定义。以下是几种常见的方法&#xff1a; 1. 内联样式 你可以直接在模板中使用style绑定来设置字体颜色。 <template><div :s…...

【配置 YOLOX 用于按目录分类的图片数据集】

现在的图标点选越来越多&#xff0c;如何一步解决&#xff0c;采用 YOLOX 目标检测模式则可以轻松解决 要在 YOLOX 中使用按目录分类的图片数据集&#xff08;每个目录代表一个类别&#xff0c;目录下是该类别的所有图片&#xff09;&#xff0c;你需要进行以下配置步骤&#x…...

Spring AI与Spring Modulith核心技术解析

Spring AI核心架构解析 Spring AI&#xff08;https://spring.io/projects/spring-ai&#xff09;作为Spring生态中的AI集成框架&#xff0c;其核心设计理念是通过模块化架构降低AI应用的开发复杂度。与Python生态中的LangChain/LlamaIndex等工具类似&#xff0c;但特别为多语…...

OPenCV CUDA模块图像处理-----对图像执行 均值漂移滤波(Mean Shift Filtering)函数meanShiftFiltering()

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 在 GPU 上对图像执行 均值漂移滤波&#xff08;Mean Shift Filtering&#xff09;&#xff0c;用于图像分割或平滑处理。 该函数将输入图像中的…...

重启Eureka集群中的节点,对已经注册的服务有什么影响

先看答案&#xff0c;如果正确地操作&#xff0c;重启Eureka集群中的节点&#xff0c;对已经注册的服务影响非常小&#xff0c;甚至可以做到无感知。 但如果操作不当&#xff0c;可能会引发短暂的服务发现问题。 下面我们从Eureka的核心工作原理来详细分析这个问题。 Eureka的…...

回溯算法学习

一、电话号码的字母组合 import java.util.ArrayList; import java.util.List;import javax.management.loading.PrivateClassLoader;public class letterCombinations {private static final String[] KEYPAD {"", //0"", //1"abc", //2"…...