
相当于树先序遍历的推广
/* 邻接表存储的图 - DFS */
void Visit( Vertex V )
{
printf("正在访问顶点%d\n", V);
}
/* Visited[]为全局变量,已经初始化为false */
void DFS( LGraph Graph, Vertex V, void (*Visit)(Vertex) )
{ /* 以V为出发点对邻接表存储的图Graph进行DFS搜索 */
PtrToAdjVNode W;
Visit( V ); /* 访问第V个顶点 */
Visited[V] = true; /* 标记V已访问 */
for( W=Graph->G[V].FirstEdge; W; W=W->Next ) /* 对V的每个邻接点W->AdjV */
if ( !Visited[W->AdjV] ) /* 若W->AdjV未被访问 */
DFS( Graph, W->AdjV, Visit ); /* 则递归访问之 */
}
1103 Integer Factorization (30分)
The K−P factorization of a positive integer N is to write N as the sum of the P-th power of K positive integers. You are supposed to write a program to find the K−P factorization of N for any positive integers N, K and P.
题目具体描述参考:https://pintia.cn/problem-sets/994805342720868352/problems/994805364711604224
题意:给定正整数N 、K、 P,把N表示成K个正整数(可以相同,递减排列)的P次方的和,即N=+...
。如果有多种方案,选择n1+...nk最大的方案,如果还有多种方案,选择底数序列的字典序最大的方案
本文介绍了一种算法——K-P因子分解,该算法旨在将一个正整数N表示为K个正整数的P次方之和。具体目标是在满足条件的前提下找到n1+...nk最大的解,并在存在多个解时选择底数序列字典序最大的解。
1405

被折叠的 条评论
为什么被折叠?



