蓝桥杯打卡Day15天


文章目录

  • 买不到的数目
  • 错误票据

一、买不到的数目OJ链接

本题思路**:**引理:给定a,b,若d=gcd(a,b)>1 ,则一定不能凑出最大数。结论:如果 a,b均是正整数且互质,那么由 ax+by,x≥0,y≥0 不能凑出的最大数是 ab−a−b。

证明:首先证明 ab−a−b不能被 ax+bx,x≥0,y≥0表示出。
反证法:假设 ab−a−b=ax+by,那么 ab=a(x+1)+b(y+1),由于 a|ab,a|a(x+1),所以 a|b(y+1),由于 a,b 互质,所以 a|(y+1),由于 y≥0,所以 a<=y+1,所以 b(y+1)≥ab。同理可得 a(x+1)≥ab,所以 a(x+1)+b(y+1)≥2ab>ab,矛盾。证明 ab−a−b+d,d>0一定可以表示成 ax+by,x,y≥0 的形式

cpp 复制代码
#include <bits/stdc++.h>

int main()
{
  std::ios::sync_with_stdio(false);
  std::cin.tie(nullptr);std::cout.tie(nullptr);
  
  int a,b;
  std::cin>>a>>b;
  
  int d=std::lcm(a,b);
  std::cout<<d-a-b<<std::endl;
  return 0;
}

二、错误票据OJ链接

**本题思路:**本题通过排序的方式来枚举即可。

cpp 复制代码
#include <bits/stdc++.h>

constexpr int N=10010;

int n,m;
int a[N];

int main()
{
  std::ios::sync_with_stdio(false);
  std::cin.tie(nullptr);std::cout.tie(nullptr);
  
  std::cin>>n;
  std::string line;
  
  //将第一行的回车读入
  std::getline(std::cin,line);
  while(n--){
    
    std::getline(std::cin,line);
    
    //stringstream 默认是以空格来分割字符串的
    std::stringstream ssin(line);
    while(ssin>>a[m]){
      m++;
    }
  }
  
  //排序
  std::sort(a,a+m);
  int d=-1,c=-1;//d是找出重复的,c是找出缺失的
  //从前往后枚举即可
  for(int i=0;i<m-1;i++){
    if(a[i]==a[i+1]) d=a[i];
    else if(a[i+1]==a[i]+2) c=a[i]+1;
  }
  
  std::cout<<c<<" "<<d<<std::endl;
  return 0;
}
相关推荐
小欣加油3 小时前
leetcode2078 两栋颜色不同且距离最远的房子
数据结构·c++·算法·leetcode·职场和发展
红星照耀华夏5 小时前
模拟面试系列-ClassLoader
面试·职场和发展
knight_9___5 小时前
Agent开发面试圣经8
面试·职场和发展
programhelp_10 小时前
WeRide OA 2026 高频真题分享 & 详细备战指南
经验分享·算法·面试·职场和发展
穿条秋裤到处跑11 小时前
每日一道leetcode(2026.04.19):下标对中的最大距离
算法·leetcode·职场和发展
叶子20242211 小时前
电网面试回答
网络·面试·职场和发展
JosieBook11 小时前
【程序人生】程序员如何实现财富自由?
程序人生·职场和发展
yangyuxuan36911 小时前
哈尔滨工业大学计算机系统原理 大作业——程序人生-Hello’s P2P
程序人生·职场和发展·课程设计
网络安全实验室11 小时前
【程序人生】程序员接私活常用平台汇总_嵌入式开发外包平台
网络·python·学习·程序人生·web安全·面试·职场和发展
2301_7953843611 小时前
计算机系统大作业——程序人生
程序人生·职场和发展·课程设计