最大最小公倍数(蓝桥杯)

问题描述

已知一个正整数N,问从1~N中任选出三个数,他们的最小公倍数最大可以为多少。

输入格式

输入一个正整数N。

输出格式

输出一个整数,表示你找到的最小公倍数。

样例输入

9

样例输出

504

数据规模与约定

1 <= N <= 106。

这题可能是网页显示问题,我以为N的范围是1到10的6次方,

所以我用的是大数相乘,后面也就没改了,就当做练习了一下大数相乘

了,除了大数相乘外,其它的思路是一样的。

可以分为N<3;

N>3;

N大于3时,分为:

1.N%2!=0   最小公倍数最大为 N*(N-1)*(N-2)

2.N%2==0   又分为

       1. N%3!=0    最小公倍数最大为 N*(N-1)*(N-3)

       2.  N%3==0    最小公倍数最大为 (N-1)*(N-2)*(N-3)

#include<stdio.h>
#include<iostream>
#include<string.h>
using namespace std;

int a[20]={0};
int f[20]={0};
int b[8]={0};
int c[8]={0};
int d[8]={0};

int bb(int q[8])
{
    for(int i=0;i<8;i++)
    {
        int t=0,g=i;
        for(int j=0;j<19;j++)
        {
            f[g]=f[g]+q[i]*a[j]+t;
            t=f[g]/10;
            f[g]=f[g]%10;
            g++;
        }
        f[g]=t;
    }
    for(int i=0;i<20;i++)
    {
        a[i]=f[i];
    }
    memset(f,0,sizeof(f));
}

int main()
{
    int N;
    cin>>N;
    int i=0;
    a[0]=1;
    int t=N;
    while(t)
    {
        b[i++]=t%10;
        t/=10;
    }
    if(N<3)
        a[0]=N;
    else if(N%2!=0)
    {
        t=N-1;
        i=0;
        while(t)
        {
            c[i++]=t%10;
            t/=10;
        }
        t=N-2;
        i=0;
        while(t)
        {
            d[i++]=t%10;
            t/=10;
        }
    }
    else
    {
        if(N%3!=0)
        {
            int t=N-1;
            i=0;
            while(t)
            {
                c[i++]=t%10;
                t/=10;
            }
            t=N-3;
            i=0;
            while(t)
            {
                d[i++]=t%10;
                t/=10;
            }
        }
        else
        {
            int t=N-2;
            i=0;
            while(t)
            {
                c[i++]=t%10;
                t/=10;
            }
            t=N-3;
            i=0;
            while(t)
            {
                d[i++]=t%10;
                t/=10;
            }
            t=N-1;
            i=0;
            while(t)
            {
                b[i++]=t%10;
                t/=10;
            }
        }
    }
    if(N>=3)
    {
        bb(b);
        bb(c);
        bb(d);
    }
    int f=19;
    while(a[f--]==0);
    for(int i=f+1;i>=0;i--)
        cout<<a[i];
    return 0;
}
时间: 2024-11-12 20:18:15

最大最小公倍数(蓝桥杯)的相关文章

算法笔记_216:第六届蓝桥杯软件类校赛部分真题(Java语言C组)

目录 1 题目一 2 题目二 3 题目三 4 题目四 5 题目五 前言:以下代码仅供参考,若有错误欢迎指正哦~ 1 题目一 二项式的系数规律,我国数学家很早就发现了. 如[图1.png],我国南宋数学家杨辉1261年所著的<详解九章算法>一书里就出现了. 其排列规律: 1 1 1 1 2 1 1 3 3 1 1 4 6 4 1 1 5 10 10 5 1 1 6 15 20 15 6 1 1 7 21 35 35 21 7 1 如下的程序,用来建立N行的杨辉三角形.请填写划线部分缺少的代码.

第四届蓝桥杯 c/c++真题

第四届蓝桥杯 c/c++真题 <1>高斯日记 问题 大数学家高斯有个好习惯:无论如何都要记日记. 他的日记有个与众不同的地方,他从不注明年月日,而是用一个整数代替,比如:4210 后来人们知道,那个整数就是日期,它表示那一天是高斯出生后的第几天.这或许也是个好习惯,它时时刻刻提醒着主人:日子又过去一天,还有多少时光可以用于浪费呢? 高斯出生于:1777年4月30日. 在高斯发现的一个重要定理的日记上标注着:5343,因此可算出那天是:1791年12月15日. 高斯获得博士学位的那天日记上标着:

蓝桥杯练习系统题解

转于:http://www.cnblogs.com/cshhr/p/3550014.html 蓝桥杯官网练习系统题解(非VIP) BEGIN-4(Fibonacci数列) 有递推公式,大家都知道用递推公式求,仅仅要记得在递推的时候同一时候取模求好 这里给一份另类代码,用矩阵高速幂求,事实上还有循环节 /* (1 1) * (Fn-1) = ( Fn )//矩阵相乘,将就着看吧 (1 0) (Fn-2) (Fn-1) (1 1) * (1 1) * (Fn-2) = ( Fn ) (1 0) (1

2015年蓝桥杯省赛B组C/C++(试题+答案)

首先说,这次我是第二次参加蓝桥杯(大学里最后一次),可这次去连个三等都没拿到,有些心灰意冷,比上一次还差, 当时看到成绩出来的时候有些失落,但是跌倒了,再站起来继续跑就可以了.可能是状态不好吧,纯属自我安慰. 接下来我把今年的题目又重新做了一遍,写下了这篇博客,如果也有需要探讨答案的,希望可以有帮助. 第一题: 第1题:统计不含4的数字 题目大意 统计10000至99999中,不包含4的数值个数. 解题分析: 第一种解法: 数学方法,这种是在网上看到的一种解法: 最高位除了0.4不能使用,其余8

蓝桥杯——算法训练之乘积最大

问题描述 今年是国际数学联盟确定的"2000--世界数学年",又恰逢我国著名数学家华罗庚先生诞辰90周年.在华罗庚先生的家乡江苏金坛,组织了一场别开生面的数学智力竞赛的活动,你的一个好朋友XZ也有幸得以参加.活动中,主持人给所有参加活动的选手出了这样一道题目: 设有一个长度为N的数字串,要求选手使用K个乘号将它分成K+1个部分,找出一种分法,使得这K+1个部分的乘积能够为最大. 同时,为了帮助选手能够正确理解题意,主持人还举了如下的一个例子: 有一个数字串:312, 当N=3,K=1时

2016 第七届蓝桥杯 c/c++ B组省赛真题及解题报告

2016 第七届蓝桥杯 c/c++ B组省赛真题及解题报告 勘误1:第6题第4个 if最后一个条件粗心写错了,答案应为1580. 条件应为abs(a[3]-a[7])!=1,宝宝心理苦啊.!感谢zzh童鞋的提醒. 勘误2:第7题在推断连通的时候条件写错了,后两个if条件中是应该是<=12 落了一个等于号.正确答案应为116. 1.煤球数目 有一堆煤球.堆成三角棱锥形.详细: 第一层放1个, 第二层3个(排列成三角形), 第三层6个(排列成三角形), 第四层10个(排列成三角形). -. 假设一共

蓝桥杯——判定字符的位置。

蓝桥杯——判断字符的位置 题目: 输入一个字符串,编写程序输出该字符串中元音字母的首次出现位置,如果没有元音字母输出0.英语元音字母只有‘a’.‘e’.‘i’.‘o’.‘u’五个. 样例输入: hello样例输出:2 样例输入: apple样例输出:1 样例输入: pmp样例输出:0 java code: import java.util.*;public class Yuanyingzifu {    public static int fun(String str)    {        

蓝桥杯 地宫取宝(12&#39;)

X 国王有一个地宫宝库.是n x m 个格子的矩阵.每个格子放一件宝贝.每个宝贝贴着价值标签. 地宫的入口在左上角,出口在右下角. 小明被带到地宫的入口,国王要求他只能向右或向下行走. 走过某个格子时,如果那个格子中的宝贝价值比小明手中任意宝贝价值都大, 小明就可以拿起它(当然,也可以不拿). 当小明走到出口时,如果他手中的宝贝恰好是k件,则这些宝贝就可以送给小明. 请你帮小明算一算,在给定的局面下,他有多少种不同的行动方案能获得这k件宝贝. [数据格式] 输入一行 3个整数,用空格分开:n m

蓝桥杯-开心的金明

//蓝桥杯-算法训练 开心的金明 //评测结果 AC //动态规划 01背包 #include <cstdio> #include <algorithm> #include <cstring> using namespace std; const int maxn = 30005; int main() { int N, m; scanf( "%d%d", &N, &m ); int f[maxn]; int v, w; memset

第六届蓝桥杯2015-省赛-C语言大学B组 个人题解

题目连接:http://course.baidu.com/view/2d86a6c1960590c69fc37622.html 1,奖券数目52488 #include <iostream> using namespace std; bool isOK(int a) { while(a) { if(a%10==4) return false; a /= 10; } return true; } int main() { int ans = 0; for(int i=10000; i<=9