当前位置: 首页 > news >正文

Date 10.27

在 Print 之前

到现在还是想不明白为什么不骗那显眼的 80pts。

赛时 420/500pts,T5放了道紫

A - 玩数字

image

P.S. \(n \le 10^{15}\)

唐题,可以 \(O(\sqrt n)\) 解决,中间进行数位分离即可,当然你也可以打表。

Code

#include <bits/stdc++.h>
#define pll pair<ll,ll>
#define pld pair<ld,ld> 
typedef long long ll;
typedef long double ld;
typedef int praise_long_long;
namespace io {using namespace std;inline ll read() {char x=getchar();ll ans=0,f=1;while(x<'0'||x>'9') {if(x=='-') {f*=(-1);}x=getchar();}while(x>='0'&&x<='9') {ans*=10;ans+=(x-'0');x=getchar();}return ans*f;}inline void print(ll x) {if(x<0) {putchar('-');x=-x;}if(x>=10) {print(x/10);putchar(x%10+'0');}else {putchar(x+'0');}}
}
using namespace io;
const ll N=2e5+5,mod=1e9+7,inf=2e18;
const ld eps=1e-6;
ll n,ans;
inline void ck(ll x) {while(x) {ll num=x%10;if(num&1) {return ;}x/=10;}ans++;
}
inline void solve() {n=read();for(ll i=0;i<=sqrt(n);i++) {ck(i*i);}print(ans);
}
praise_long_long main() {
//	freopen("num.in","r",stdin);
//	freopen("num.out","w",stdout);ll T=1;
//	T=read();while(T--) {solve();}return 0;
}
/**/

B - 课程

image

P.S. \(1 \le n \le 5 \times 10^{5} \ \ \ 1 \le a_i,b_i \le 10^9\)

又是一道唐题,需要注意的是输入进来 \(2 \times n\) 个数,所以空间开到 \(10^6\) 即可。

Code

#include <bits/stdc++.h>
#define pll pair<ll,ll>
#define pld pair<ld,ld>
typedef long long ll;
typedef long double ld;
typedef int praise_long_long;
namespace io {using namespace std;inline ll read() {char x=getchar();ll ans=0,f=1;while(x<'0'||x>'9') {if(x=='-') {f*=(-1);}x=getchar();}while(x>='0'&&x<='9') {ans*=10;ans+=(x-'0');x=getchar();}return ans*f;}inline void print(ll x) {if(x<0) {putchar('-');x=-x;}if(x>=10) {print(x/10);putchar(x%10+'0');}else {putchar(x+'0');}}
}
using namespace io;
const ll N=1e6+5,mod=1e9+7,inf=2e18;
const ld eps=1e-6;
struct node {ll al,bl,pos;
} a[N];
ll n,ans;
inline void solve() {n=read();for(ll i=1;i<=2*n;i++) {a[i]={read(),read(),i};}sort(a+1,a+1+2*n,[](node a,node b) {return a.al-a.bl>b.al-b.bl;});for(ll i=1;i<=n;i++) {ans+=a[i].al;
//		cout<<a[i].pos<<' ';}
//	puts("");for(ll i=n+1;i<=2*n;i++) {ans+=a[i].bl;}print(ans);
}
praise_long_long main() {
//	freopen("course.in","r",stdin);
//	freopen("course.out","w",stdout);ll T=1;
//	T=read();while(T--) {solve();}return 0;
}
/**/

C - 卡牌

image

其实很简单,我们发现只要位数短的肯定没有位数长的大,所以优先考虑数的数量,然后从小往大排序即可。

Code

#include <bits/stdc++.h>
#define pll pair<ll,ll>
#define pld pair<ld,ld>
typedef long long ll;
typedef long double ld;
typedef int praise_long_long;
namespace io {using namespace std;inline ll read() {char x=getchar();ll ans=0,f=1;while(x<'0'||x>'9') {if(x=='-') {f*=(-1);}x=getchar();}while(x>='0'&&x<='9') {ans*=10;ans+=(x-'0');x=getchar();}return ans*f;}inline void print(ll x) {if(x<0) {putchar('-');x=-x;}if(x>=10) {print(x/10);putchar(x%10+'0');}else {putchar(x+'0');}}
}
using namespace io;
const ll N=1e6+5,mod=1e9+7,inf=2e18;
const ld eps=1e-6;
ll n,q,a[N],num,sum[N];
inline void solve() {n=read(),q=read();for(ll i=0;i<n;i++) {a[i]=read();num+=a[i]*i;}if(num%(n-1)) {a[num%(n-1)]--;}sum[0]=a[0];for(ll i=1;i<n;i++) {sum[i]=sum[i-1]+a[i];}while(q--) {ll kl=read();ll l=0,r=n-1,cnt=-1;while(l<=r) {ll mid=(l+r>>1);if(sum[mid]>kl) {cnt=mid;r=mid-1;}else {l=mid+1;}}print(cnt);puts("");}
}
praise_long_long main() {
//	freopen("card.in","r",stdin);
//	freopen("card.out","w",stdout);ll T=1;
//	T=read();while(T--) {solve();}return 0;
}
/**/

D - 排队

image

事实上不知为何,我甚至还推了一个小时的杨辉三角

听说有人用 Catalan 数写了,但很明显,我没推出来,所以可以推规律。

我们可以讨论 \(1\)\(j\) 号位的方案数:

\[1:1 \\ 2:1 \ 1 \\ 3:1 \ 2 \ 2 \\ 4:1 \ 3 \ 5 \ 5 \\ 5:1 \ 4 \ 8 \ 14 \ 14 \]

我们可以定义 \(f_{i,j}\) 表示当 \(n=i\)\(1\)\(j\) 号位的方案数。

不难发现,\(f_{i,j}=f_{i-1,j}+sum_{j-1}\) 其中 \(sum_j\) 表示上一次操作 \(j\) 及之前的贡献和。

答案就是 \(\sum_{i=1}^{n} f_{n,i}\)

Code

#include <bits/stdc++.h>
#define pll pair<ll,ll>
#define pld pair<ld,ld>
typedef int ll;
typedef long double ld;
typedef int praise_long_long;
namespace io {using namespace std;inline ll read() {char x=getchar();ll ans=0,f=1;while(x<'0'||x>'9') {if(x=='-') {f*=(-1);}x=getchar();}while(x>='0'&&x<='9') {ans*=10;ans+=(x-'0');x=getchar();}return ans*f;}inline void print(ll x) {if(x<0) {putchar('-');x=-x;}if(x>=10) {print(x/10);putchar(x%10+'0');}else {putchar(x+'0');}}
}
using namespace io;
const ll N=5e3+5,mod=1e7+7,inf=2e9;
const ld eps=1e-6;
ll n,f[N][N],sum[N];
inline void solve() {n=read();f[1][1]=1,sum[1]=1;for(ll i=2;i<=n;i++) {for(ll j=1;j<=i;j++) {f[i][j]=f[i-1][j]+sum[j-1];f[i][j]%=mod;}for(ll j=1;j<=i;j++) {sum[j]=sum[j-1]+f[i][j];sum[j]%=mod;}}print(sum[n]);
}
praise_long_long main() {
//	freopen("eat.in","r",stdin);
//	freopen("eat.out","w",stdout);ll T=1;
//	T=read();while(T--) {solve();}return 0;
}
/**/
http://www.hn-smt.com/news/356/

相关文章:

  • 读书日记3
  • Tuack 生成 OI 比赛题目 PDF 笔记
  • 数据库三大范式、Union和Union all的区别
  • CSP-S2025 游记
  • 「LG3600-随机数生成器」题解
  • MathType7下载包安装教程2025最新下载+安装+汉化激活(附安装包,超详细)
  • 2025强网杯ezphp复现
  • 漏洞报告被拒绝的常见原因及避免方法
  • 【IEEE出版 | 重庆邮电大学主办 | 多届次、高层次】第六届人工智能与计算机工程国际学术会议(ICAICE 2025)
  • Docker容器里面部署的Jenkins的Java17升级到21版本(无需删除之前容器,内部在线升级) - 攻城狮
  • 报表知识
  • 渐进过程中大O与小o混用
  • 消息队列的有序性
  • 【LTDC】DMA2D —— 嵌入式系统的 GPU
  • unity管理器设计:Manager of Managers
  • iview table 排序 columns 里面写 sortable: custom 不要写 sortable: true 不然会进行二次内部排序序号等 字段。
  • 本地运行nginx服务,模拟线上环境访问项目
  • git提交远程项目步骤
  • 2025 年搅拌器搅拌设备,侧入式搅拌设备,斜插式揽拌设备,卧式搅拌设备厂家最新推荐,聚焦资质、案例、售后的五家企业深度解读
  • 2025 年环保搅拌设备,搅拌装置设备,框式搅拌设备厂家最新推荐,实力品牌深度解析采购无忧之选!
  • CorelDRAW的shell扩展ShellXP.dll导致资源管理器explorer.exe卡死/冻结/无响应/挂起
  • 2025 年定制矿车,大型矿车,固定式矿车厂家最新推荐,产能、专利、环保三维数据透视
  • 醒图电脑版下载与安装教程(2025最新版)
  • 2025 年江苏电缆附件,热缩电缆附件,冷缩电缆附件,预制电缆附件厂家最新推荐,产能、专利、环保三维数据透视
  • Android Studio 使用glibc2.28的版本
  • 2025年10月兰花油品牌推荐榜:五款精华油深度对比与选购指南
  • 2025年浅拾兰花双萃致臻精华油:从成分与技术维度解析其护肤功效
  • 2025 年进口螺杆泵,萨伯特螺杆泵,污泥螺杆泵厂家最新推荐,实力品牌深度解析采购无忧之选!
  • 为什么 AI 模型的最小理解单位是「特征」?
  • 2025年移动车载变电站厂家最新推荐榜:陕西四方华能凭硬实力成优选