CSP-J入门组

简介: CSP-J入门组

CSP-J入门组

简单排序:


图书馆中每本书都有一个图书编码,可以用于快速检索图书,这个图书编码是一个正整数。每位借书的读者手中有一个需求码,这个需求码也是一个正整数。如果一本书的图书编码恰好以读者的需求码结尾,那么这本书就是这位读者所需要的。小 D 刚刚当上图书馆的管理员,她知道图书馆里所有书的图书编码,她请你帮她写一个程序,对于每一位读者,求出他所需要的书中图书编码最小的那本书,如果没有他需要的书,请输出-1。

image.png

#include<stdio.h>#include<stdlib.h>intcmp(constvoid*a, constvoid*b){
return (*(int*)a-*(int*)b);
}
intmod(intx){
inti, sum=1;
for(i=1; i<=x; i++)
    {
sum*=10;
    }
returnsum;
}
intmain()
{
intn, q, len[1002];
scanf("%d%d", &n, &q);
inti, j, num[1002], q1[1002];
for(i=1; i<=n; i++)
scanf("%d", &num[i]);
for(i=1; i<=q; i++)
scanf("%d%d", &len[i], &q1[i]);
qsort(num, n+1, sizeof(int), cmp);
for(i=1; i<=q; i++)
    {
for(j=1; j<=n; j++)
  {
if(num[j]%mod(len[i])==q1[i])
    {
printf("%d\n", num[j]);
break;
    }
elseif(j==n)
printf("-1\n");
  }
    }
return0;
}


字符串


给定一个整数,请将该数各个位上数字反转得到一个新数。新数也应满足整数的常见形式,即除非给定的原数为零,否则反转后得到的新数的最高位数字不应为零(参见样例2)。

image.png

#include<iostream>usingnamespacestd;
intmain()
{
intn,a,b=0;
cin>>n;
while(n!=0)
    {
a=n%10;
n=n/10;
b=b*10+a;
    }
cout<<b<<endl;
return0;
}


二分:二分法是指对于区间[a,b]上连续不断且f(a)·f(b)<0的函数y=f(x),通过不断地把函数f(x)的零点所在的区间一分为二,使区间的两个端点逐步逼近零点,进而得到零点近似值的方法。


有形如:ax3+bx2+cx+d=0 这样的一个一元三次方程。给出该方程中各项的系数(a,b,c,d 均为实数),并约定该方程存在三个不同实根(根的范围在-100至100之间),且根与根之差的绝对值 ≥ 1。要求由小到大依次在同一行输出这三个实根(根与根之间留有空格),并精确到小数点后2位。

提示:记方程f(x) = 0,若存在2个数x1和x2,且x1 < x2,f(x1)*f(x2) < 0,则在(x1,x2)之间一定有一个根。

image.png

#include<bits/stdc++.h>usingnamespacestd;
doublea,b,c,d,l,r,mid;
doubles(doubles)
{
returna*pow(s,3)+b*pow(s,2)+c*pow(s,1)+d;
}
intmain()
{
cin>>a>>b>>c>>d;
for(inti=-100;i<=100;i++)
    {
l=i,r=i+1;
if(s(l)==0) cout<<fixed<<setprecision(2)<<l<<" ";
elseif(s(l)*s(r)<0)
        {
while(r-l>=1e-5)
            {
mid=(r+l)/2;
if(s(r)*s(mid)<0) l=mid;
elser=mid;
            }
cout<<fixed<<setprecision(2)<<l<<" ";
        }
    }
return0;
}


高精度:高精度运算,是指参与运算的数(加数,减数,因子……)范围大大超出了标准数据类型(整型,实型)能表示的范围的运算。


给出一个整数 n(n<1030) 和 k 个变换规则(k<=15)。

规则:

一位数可变换成另一个一位数:规则的右部不能为零。

例如:n=234。有规则(k=2):

2-> 5

3-> 6

上面的整数 234 经过变换后可能产生出的整数为(包括原数):

234

534

264

564

共 4 种不同的产生数

问题:

给出一个整数 n 和 k 个规则。

求出:

经过任意次的变换(0次或多次),能产生出多少个不同整数。仅要求输出个数。

image.png

#include<iostream>usingnamespacestd;
strings;
intn,f[10][10],a[100010],c[100010];
voidwork()
{
cin>>s>>n;
for(inti=1;i<=n;i++)
    {
intx,y;
cin>>x>>y;
f[x][y]=1;
    }
for(intk=0;k<=9;k++)
for(inti=0;i<=9;i++)
for(intj=0;j<=9;j++)
if(i!=j&&i!=k&&j!=k&&f[i][k]&&f[k][j]) f[i][j]=1;
for(inti=0;i<=9;i++)
for(intj=0;j<=9;j++)
if(f[i][j]) a[i]++;
intd=1;
c[1]=1;
for(intj=0;j<s.size();j++)
    {
intx=0;
inte=s[j]-'0';
e=a[e]+1;
for(inti=1;i<=d;i++)
        {
c[i]=c[i]*e+x;
x=c[i]/10;
c[i]%=10;
        }
if(x>0) c[++d]=x;
    }
for(inti=d;i>=1;i--)
cout<<c[i];
cout<<"\n";
}
intmain()
{
work();
return0;
}


排列组合数学:

妞妞参加了Nowcoder Girl女生编程挑战赛, 但是很遗憾, 她没能得到她最喜欢的黑天鹅水晶项链。


于是妞妞决定自己来制作一条美丽的项链。一条美丽的项链需要满足以下条件:

1、需要使用n种特定的水晶宝珠

2、第i种水晶宝珠的数量不能少于li颗, 也不能多于ri颗

3、一条美丽的项链由m颗宝珠组成

妞妞意识到满足条件的项链种数可能会很多, 所以希望你来帮助她计算一共有多少种制作美丽的项链的方案。

image.png

#include<cstdio>// #include <algorithm>// using namespace std;#definemax(a, b) ((a) > (b) ? (a) : (b))
#definelllonglongconstintM=1e5+10;
intarr[M];
lldp[25][105];
boolvis[25][105];
structnumber{
intl, r;
}req[25];
llDP(intn, intw) {
if (w<0) return0;
if (n==0&& (w>req[0].r||w<req[0].l)) return0;
if (n==0) return1;
if (vis[n][w]) returndp[n][w];
vis[n][w] =true;
ll&ret=dp[n][w];
for (inti=req[n].l; i<=req[n].r; ++i) {
ret+=DP(n-1, w-i);
    }
returnret;
}
intmain() {
intn, m;
scanf("%d %d\n", &n, &m);
for (inti=0; i<n; ++i) {
intl, r;
scanf("%d %d", &l, &r);
req[i] = {.l=l, .r=r};
    }
printf("%lld", DP(n-1, m));
return0;
}


递归排序:

哈希:散列函数(又称散列算法、哈希函数)能够从某一类数据中提取出一个有限长度的数字指纹作为数据的代表,这个”指纹“被称为散列值(哈希值)。散列函数产生的结果通常会比原数据小,从而实现数据的压缩;同时通过散列函数的计算过程是不可逆的,即无法根据散列值反推出原始数据,所以散列函数被广泛用于需要生成数据摘要或实现数据加密的应用场景中。[1]对于散列函数的选择,通常需要结合散列结果的冲突率、散列函数计算的代价来综合考虑。


基本递推


动态规划


贪心:贪婪算法是一种算法范例,它遵循在每个阶段做出局部最优选择[1] 的启发式求解方法,目的是寻找到一个全局最优解。在许多问题中,贪婪策略通常不会产生最优解,但是贪婪启发式可能会在合理的时间内产生近似全局最优解的局部最优解。


树形结构


枚举和暴力:在数学和计算机科学理论中,一个集的枚举是列出某些有穷序列集的所有成员的程序,或者是一种特定类型对象的计数。

暴力:利用枚举所有的情况,或者其它大量运算又不用技巧的方式,来求解问题的方法。广义的暴力法在解决问题,特别是数学和计算机编程问题方面应用广泛,有着巨大的作用。它的缺点是效率低下,优点是编码复杂度低,几乎不用思考,不容易出错。狭义的暴力法:这是一种简单的串匹配算法,用来判断一个短串t是不是一个长串s的子串。


01背包


区间dp


完全背包


多重背包


目录
相关文章
|
4月前
|
JSON API 开发者
淘宝 API 零基础快速上手教程(2025 版)
淘宝API是淘宝开放平台提供的接口,允许开发者获取商品、订单等数据,并实现自动化操作。本文介绍了API基础概念、账号开通流程、权限申请、调用方法及实战示例,适合零基础开发者快速入门并掌握淘宝API的核心使用技巧。
|
10月前
|
Web App开发 JSON 测试技术
API测试工具集合:让接口测试更简单高效
在当今软件开发领域,接口测试工具如Postman、Apifox、Swagger等成为确保API正确性、性能和可靠性的关键。Postman全球闻名但高级功能需付费,Apifox则集成了API文档、调试、Mock与自动化测试,简化工作流并提高团队协作效率,特别适合国内用户。Swagger自动生成文档,YApi开源但功能逐渐落后,Insomnia界面简洁却缺乏团队协作支持,Paw仅限Mac系统。综合来看,Apifox是国内用户的理想选择,提供中文界面和免费高效的功能。
|
存储 安全 算法
RSA在手,安全我有!Python加密解密技术,让你的数据密码坚不可摧
【9月更文挑战第11天】在数字化时代,信息安全至关重要。传统的加密方法已难以应对日益复杂的网络攻击。RSA加密算法凭借其强大的安全性和广泛的应用场景,成为保护敏感数据的首选。本文介绍RSA的基本原理及在Python中的实现方法,并探讨其优势与挑战。通过使用PyCryptodome库,我们展示了RSA加密解密的完整流程,帮助读者理解如何利用RSA为数据提供安全保障。
382 5
|
安全 网络安全 网络虚拟化
零信任SDP是什么,有什么作用
综上所述,零信任SDP通过其独特的安全架构为企业网络安全提供了强大的保护屏障。在网络威胁日益增多的当代,采用零信任SDP可以帮助企业防范安全风险,保护敏感数据,同时为用户提供高效便捷的访问体验。
497 4
振弦采集仪在大型工程安全监测中的作用与意义
振弦采集仪在大型工程安全监测中的作用与意义
振弦采集仪在大型工程安全监测中的作用与意义
|
SQL 关系型数据库 MySQL
|
安全 JavaScript 前端开发
Nginx服务扫描漏洞修复
Nginx服务扫描漏洞修复
|
Dart 前端开发 JavaScript
dart-sass与node-sass的区别以及使用dart-sass可能会出现的问题
dart-sass与node-sass的区别以及使用dart-sass可能会出现的问题
1997 0
dart-sass与node-sass的区别以及使用dart-sass可能会出现的问题
|
机器学习/深度学习 算法 自动驾驶
深度强化学习在大模型中的应用:现状、问题和发展
强化学习在大模型中的应用具有广泛的潜力和机会。通过使用强化学习算法,如DQN、PPO和TRPO,可以训练具有复杂决策能力的智能体,在自动驾驶、机器人控制和游戏玩家等领域取得显著成果。然而,仍然存在一些挑战,如样本效率、探索与利用平衡以及可解释性问题。未来的研究方向包括提高样本效率、改进探索策略和探索可解释的强化学习算法,以进一步推动强化学习在大模型中的应用。
3262 3
|
Web App开发 人工智能 自然语言处理
2023 年最好的36款 AI 生产力工具(七)
本文主要展示了36 款 AI 应用,可以帮助读者更快、更好地工作。每个人都在与ChatGPT交流,从完整的博客文章到特定代码行的功能都在询问。其结果令人惊叹。虽然我们仍在探索如何将这项技术纳入我们的工作流程中,但明显的是,人工智能工具正在改变游戏规则。尽管ChatGPT是目前最受欢迎的,但它远不是首款进入市场的人工智能应用程序。经过Zapier团队的大量研究和测试,总结出了以下36款能够改变工作方式的人工智能生产力工具。
312 1