- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我是编码初学者。我想使用简单的递归和数组来解决以下问题。但我无法想象它。我想出了使用链接列表的解决方案。以下是问题和我的解决方法
Given n rows of integers, such that the ith row (
1 <= i <= n
) contains i integers. Using the following set of path rules, find the path having the maximum weight.Path traversal rules:
A valid path sequence would be top-down i.e. begins with the integer in the first row, and traverses all rows selecting only one integer in each row.
From any jth integer in the ith row i.e.
row[i][j]
, traversal can happen either downward (i.e. torow[i+1][j]
) or diagonally downward to the right (i.e. torow[i+1][j+1]
).The weight of a Path is the sum of values of integers in the Path sequence.
Example:
No. of Rows: 5
4
2 9
15 1 3
16 92 41 44
8 142 6 4 8Expected Output: 4, 2, 15, 92, 142 (Max weight is 255)
解.c
#include<stdio.h>
#include<stdlib.h>
int n,**ar;
struct n
{
int i,j;
int w;
struct n *ptr;
};
struct n* maxweight(int i,int j,struct n* x)
{
struct n* tmp=malloc(sizeof(struct n)),*t1,*t2;
tmp->i=i;
tmp->j=j;
tmp->ptr=x;
tmp->w=ar[i][j];
if(x)tmp->w+=x->w;
if(i==n-1)return tmp;
t1=maxweight(i+1,j,tmp);
t2=maxweight(i+1,j+1,tmp);
if(t1->w>t2->w)return t1;
return t2;
}
int main()
{
int i,j;
struct n * s;
printf("Enter the value of n\n");
scanf("%d",&n);
ar=malloc(n*sizeof(int*));
for(i=0;i<n;i++)
{
ar[i]=malloc((i+1)*sizeof(int));
for(j=0;j<=i;j++)scanf("%d",&ar[i][j]);
}
s=maxweight(0,0,NULL);
printf("MAX WEIGHT is :%d\nPATH: ",s->w);
while(s)
{
printf("%d ",ar[s->i][s->j]);
s=s->ptr;
}
printf("\n");
return 0;
}
如何在没有使用 n x n 矩阵的链接列表的情况下使用递归简单地解决这个问题?动态规划是否适用于此问题。
最佳答案
专注于计算前方路径的权重; 不要回头看。
首先解决一个微不足道的边缘案例。假设你到了最后一行。然后就没有什么可遵循的了;剩余路径的权重为零。
在代码中:
int getWeight(int i, int j)
{
int remaining = 0;
在任何其他行中,您必须做出选择。你应该向左还是向右?由于此时无法知道哪一个是最好的,您只需要尝试两个方向:
if (i < lastRow)
{
int weightLeft = getWeight(i + 1, j);
int weightRight = getWeight(i + 1, j + 1);
注意我递归调用了我自己的函数; 盲目相信该函数能够为剩余路径提供最佳权重!
尝试了两个方向后,选择权重最高的那个:
int best_j = weightLeft > weightRight ? j : j + 1;
现在我们再走一遍选择的路。
remaining = getWeight(i + 1, best_j);
}
这不是很有效,但它有助于收集最佳路径的各个步骤。我将使用一个简单的数组 pathColumns
。
pathColumns[i] = j;
最后,我们需要对这些值求和。
return row[i][j] + remaining;
}
要让整个事情开始运转,只需调用该函数,并将顶部单元格的坐标传递给它。出于实际原因,我将所有数组设为基数为 0。所以最上面的单元格是 row[0][0]
。
printf("Optimal weight: %d\n", getWeight(0, 0));
综合起来:
#include <stdio.h>
#define n 5
int pathColumns[n] = {0};
int row[n][n] =
{
{4},
{2, 9},
{15, 1, 3},
{16, 92, 41, 44},
{8, 142, 6, 4, 8}
};
int getWeight(int i, int j)
{
int remaining = 0;
if (i < n-1) /* with base-0, the last row is n-1 */
{
int weightLeft = getWeight(i + 1, j);
int weightRight = getWeight(i + 1, j + 1);
int best_j = weightLeft > weightRight ? j : j + 1;
remaining = getWeight(i + 1, best_j);
}
pathColumns[i] = j;
return row[i][j] + remaining;
}
int main()
{
int i;
printf("Optimal weight: %d\n", getWeight(0, 0));
for (i = 0; i < n; i++)
{
int j = pathColumns[i];
printf("(%d, %d) = %d\n", i+1, j+1, row[i][j]);
/* NOTE: +1 is a correction to bring the output back to base-1 */
}
return 0;
}
输出:
Optimal weight: 255
(1, 1) = 4
(2, 1) = 2
(3, 1) = 15
(4, 2) = 92
(5, 2) = 142
我们希望 getWeight(0, 0)
返回这个金字塔最重的路径。
4 <---- (0, 0) is our starting point
/ \
2 9
/ \ / \
15 1 3
/ \ / \ / \
16 92 41 44
/ \ / \ / \ / \
8 142 6 4 8
递归算法进行两次递归调用。
getWeight(1, 0)
必须获取起点左侧下方子金字塔的最重路径。getWeight(1, 1)
必须获取起点右侧下方子金字塔的最重路径。两个子金字塔:
2 <--- (1, 0) 9 <--- (1, 1)
/ \ / \
15 1 1 3
/ \ / \ / \ / \
16 92 41 92 41 44
/ \ / \ / \ / \ / \ / \
8 142 6 4 142 6 4 8
假设 getWeight(1, 0)
和 getWeight(1, 1)
返回正确的权重(分别为 251 和 244),剩下要做的就是选择最高的一个 (251) 并将大金字塔的顶部值添加到它 (4)。结果是 255。
我们所做的是减少一个问题(计算高度为 5 的金字塔的最大重量),这样我们就剩下两个较小的问题需要解决(计算高度为 4 的金字塔的最大重量)。同样,我们可以将高度 4 的问题简化为高度 3 的相同问题。例如,getWeight(1, 1)
将进行两次递归调用 getWeight(2, 1)
和 getWeight(2, 2)
:
1 <--- (2, 1) 3 <--- (2, 2)
/ \ / \
92 41 41 44
/ \ / \ / \ / \
142 6 4 6 4 8
getWeight(1, 1)
应该返回 244 = 9 + max(235, 55)。
继续这种方式,我们最终解决了高度为 1 的金字塔的问题。这些是原始金字塔底部的值(8、142、6、4 和 8)。递归到此结束;高度为 1 的金字塔只不过是一个节点。该节点的值是通过该金字塔的(唯一)路径的权重。
关于c - 如何使用递归来制定使用简单数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33835285/
我正在尝试创建一个包含 int[][] 项的数组 即 int version0Indexes[][4] = { {1,2,3,4}, {5,6,7,8} }; int version1Indexes[
我有一个整数数组: private int array[]; 如果我还有一个名为 add 的方法,那么以下有什么区别: public void add(int value) { array[va
当您尝试在 JavaScript 中将一个数组添加到另一个数组时,它会将其转换为一个字符串。通常,当以另一种语言执行此操作时,列表会合并。 JavaScript [1, 2] + [3, 4] = "
根据我正在阅读的教程,如果您想创建一个包含 5 列和 3 行的表格来表示这样的数据... 45 4 34 99 56 3 23 99 43 2 1 1 0 43 67 ...它说你可以使用下
我通常使用 python 编写脚本/程序,但最近开始使用 JavaScript 进行编程,并且在使用数组时遇到了一些问题。 在 python 中,当我创建一个数组并使用 for x in y 时,我得
我有一个这样的数组: temp = [ 'data1', ['data1_a','data1_b'], ['data2_a','data2_b','data2_c'] ]; // 我想使用 toStr
rent_property (table name) id fullName propertyName 1 A House Name1 2 B
这个问题在这里已经有了答案: 关闭13年前。 Possible Duplicate: In C arrays why is this true? a[5] == 5[a] array[index] 和
使用 Excel 2013。经过多年的寻找和适应,我的第一篇文章。 我正在尝试将当前 App 用户(即“John Smith”)与他的电子邮件地址“jsmith@work.com”进行匹配。 使用两个
当仅在一个边距上操作时,apply 似乎不会重新组装 3D 数组。考虑: arr 1),但对我来说仍然很奇怪,如果一个函数返回一个具有尺寸的对象,那么它们基本上会被忽略。 最佳答案 这是一个不太理
我有一个包含 GPS 坐标的 MySQL 数据库。这是我检索坐标的部分 PHP 代码; $sql = "SELECT lat, lon FROM gps_data"; $stmt=$db->query
我需要找到一种方法来执行这个操作,我有一个形状数组 [批量大小, 150, 1] 代表 batch_size 整数序列,每个序列有 150 个元素长,但在每个序列中都有很多添加的零,以使所有序列具有相
我必须通过 url 中的 json 获取文本。 层次结构如下: 对象>数组>对象>数组>对象。 我想用这段代码获取文本。但是我收到错误 :org.json.JSONException: No valu
enter code here- (void)viewDidLoad { NSMutableArray *imageViewArray= [[NSMutableArray alloc] init];
知道如何对二维字符串数组执行修剪操作,例如使用 Java 流 API 进行 3x3 并将其收集回相同维度的 3x3 数组? 重点是避免使用显式的 for 循环。 当前的解决方案只是简单地执行一个 fo
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我有来自 ASP.NET Web 服务的以下 XML 输出: 1710 1711 1712 1713
如果我有一个对象todo作为您状态的一部分,并且该对象包含数组列表,则列表内部有对象,在这些对象内部还有另一个数组listItems。如何更新数组 listItems 中 id 为“poi098”的对
我想将最大长度为 8 的 bool 数组打包成一个字节,通过网络发送它,然后将其解压回 bool 数组。已经在这里尝试了一些解决方案,但没有用。我正在使用单声道。 我制作了 BitArray,然后尝试
我们的数据库中有这个字段指示一周中的每一天的真/假标志,如下所示:'1111110' 我需要将此值转换为 boolean 数组。 为此,我编写了以下代码: char[] freqs = weekday
我是一名优秀的程序员,十分优秀!