当前位置: 首页 > 工具软件 > School Kids > 使用案例 >

A - Nicoleta and the circle of kids(最大生成树)

林夕
2023-12-01

A - Nicoleta and the circle of kids

Nicoleta is a happy kid, he goes every day to school and is always complaining about waking up early and having to complete his homework assignments. His favorite professor, Afonsox, is very funny and created a new challenge for him.

Even though Nicoleta is just a kid, Afonsox introduced him to the world of graph theory. Nicoleta is amazed, he is very obsessed with this graph that Afonsox decided to call K-round graph. A K-round graph with N vertices is a graph where every vertex u, numbered from 0 to N - 1, has an edge to vertices (u + 1)%N, …, (u + K)%N. Here a%b is the operator that gives the remainder of the integer division of a by b. Also, an edge between vertices u and (u + i)%N has value i.

Nicoleta likes this graph because if you draw it, it looks like a circle of kids, where each kid has K arms with different lengths with which they can reach the K next kids, like the picture below, which he drew in his notebook. Imagining this makes Nicoleta smile.

Figure: A 2-round graph with 4 vertices drawn by Nicoleta.
The challenge Afonsox has proposed to Nicoleta is for him to find the sum of all the values of the edges in the maximum spanning tree of a given K-round graph. A maximum spanning tree of a graph is composed of all of its vertices and a subset of edges such that there is one and only one path from one vertex to another and the sum of the values of the edges is maximal. Can you help Nicoleta finding the answer to Afonsox challenge?

Input
The input consists of a single line containing two integers N and K (1 ≤ K < N ≤ 109), indicating the number of vertices in the graph and the number of outgoing edges from every vertex.

Output
Output a single integer - the sum of the values of the edges in the maximum spanning tree of the K-round graph.

Examples
Input
3 2
Output
4
Input
6 2
Output
9

#include <cstdio>
#include <cstring>
#include <string>
#include <cmath>
#include <iostream>
#include <algorithm>
using namespace std;
typedef long long LL;
LL n, k;

LL gcd(int a, int b)
{
    return b ? gcd(b, a % b) : a;
    
}

LL lcm(LL x, LL y)
{
    return x / gcd(x, y) * y;
}

int main()
{
    while(~scanf("%lld %lld", &n, &k))
    {
        LL g = gcd(n, k), l = lcm(n, k);
        LL cnt = l / k - 1, group = n * k / l;
        LL ans = group * cnt * k + (group - 1) * (k - 1);

        printf("%lld\n", ans);
    }
    return 0;
}


 类似资料: