第二次CCF计算机软件能力认证

news2024/11/13 9:25:01

第一题:相邻数对

给定 n 个不同的整数,问这些数中有多少对整数,它们的值正好相差 1。

输出格式

输入的第一行包含一个整数 n,表示给定整数的个数。

第二行包含所给定的 n 个整数。

输出格式

输出一个整数,表示值正好相差 1 的数对的个数。

数据范围

1≤n≤1000,
给定的整数为不超过 10000 的非负整数。

输入样例:

6
10 2 6 3 7 8

输出样例:

3

样例解释

值正好相差 1 的数对包括 (2,3),(6,7),(7,8)。

解题思路:直接进行模拟即可。

以下是代码:

c++

#include<iostream>

using namespace std;

const int N = 1010;
int a[N] , n;

int main()
{
    cin >> n;
    for(int i = 0;i < n;i ++)
        cin >> a[i];
    
    long long res = 0;
    for(int i = 0;i < n;i ++)
        for(int j = i + 1;j < n;j ++)
            if(abs(a[i] - a[j]) == 1) res ++;
    cout << res << endl;
    return 0;
}

python

n = int(input())
l = list(map(int , input().split()))
res = 0
for i in range(n):
    for j in range(i + 1 , n):
        if abs(l[i] - l[j]) == 1:
            res += 1
print(res)

第二题:画图

在一个定义了直角坐标系的纸上,画一个 (x1,y1) 到 (x2,y2) 的矩形指将横坐标范围从 x1 到 x2,纵坐标范围从 y1 到 y2 之间的区域涂上颜色。

下图给出了一个画了两个矩形的例子。

第一个矩形是 (1,1) 到 (4,4),用绿色和紫色表示。

第二个矩形是 (2,3) 到 (6,5),用蓝色和紫色表示。

图中,一共有 15 个单位的面积被涂上颜色,其中紫色部分被涂了两次,但在计算面积时只计算一次。

在实际的涂色过程中,所有的矩形都涂成统一的颜色,图中显示不同颜色仅为说明方便。

给出所有要画的矩形,请问总共有多少个单位的面积被涂上颜色。

输入格式

输入的第一行包含一个整数 n,表示要画的矩形的个数。

接下来 n 行,每行 4 个非负整数,分别表示要画的矩形的左下角的横坐标与纵坐标,以及右上角的横坐标与纵坐标。

输出格式

输出一个整数,表示有多少个单位的面积被涂上颜色。

数据范围

1≤n≤100,
0≤ 横坐标、纵坐标 ≤100

输入样例:

2
1 1 4 4
2 3 6 5

输出样例:

15

解题思路:直接进行模拟即可。

以下是代码:

c++

#include<iostream>
#include<cstring>

using namespace std;

const int N = 110;
int t;
bool st[N][N];

int main()
{
    memset(st , 0 , sizeof st);
    cin >> t;
    while(t --)
    {
        int a , b , c , d;
        cin >> a >> b >> c >> d;
        for(int i = a;i < c;i ++)
            for(int j = b;j < d;j ++)
                st[i][j] = true;
    }
    int res = 0;
    for(int i = 0;i < N;i ++)
        for(int j = 0;j < N;j ++)
            if(st[i][j]) res ++;

    cout << res << endl;
    return 0;
}

python

st = [[False] * 105 for i in range(105)]
for _ in range(int(input())):
    a , b , c , d = map(int , input().split())
    for i in range(a , c):
        for j in range(b , d):
            st[i][j] = True
res = 0
for i in range(101):
    for j in range(101):
        if st[i][j]:
            res += 1
print(res)

第三题:字符串匹配

给出一个字符串和多行文字,在这些文字中找到字符串出现的那些行。

你的程序还需支持大小写敏感选项:当选项打开时,表示同一个字母的大写和小写看作不同的字符;当选项关闭时,表示同一个字母的大写和小写看作相同的字符。

输入格式

输入的第一行包含一个字符串 S,由大小写英文字母组成。

第二行包含一个数字,表示大小写敏感的选项,当数字为 0 时表示大小写不敏感,当数字为 1 时表示大小写敏感。

第三行包含一个整数 n,表示给出的文字的行数。

接下来 n 行,每行包含一个字符串,字符串由大小写英文字母组成,不含空格和其他字符。

输出格式

输出多行,每行包含一个字符串,按出现的顺序依次给出那些包含了字符串 S 的行。

数据范围

1≤n≤100,
每个字符串的长度不超过 100。

输入样例:

Hello
1
5
HelloWorld
HiHiHelloHiHi
GrepIsAGreatTool
HELLO
HELLOisNOTHello

输出样例:

HelloWorld
HiHiHelloHiHi
HELLOisNOTHello

样例解释

在上面的样例中,第四个字符串虽然也是 Hello,但是大小写不正确。

如果将输入的第二行改为 0,则第四个字符串应该输出。

 解题思路:如果判断类型是0,那么统一将所有的大写字母改成小写字母,只需要枚举每一个字母,将大写字母使用异或32即可得到小写字母。

以下是代码:

c++

#include<iostream>
#include<algorithm>

using namespace std;

string s;
int type , t;

string change(string str)
{
    string res;
    for(char i : str)
        if(i <= 'Z') res += i ^ 32;
        else res += i;
    return res;
}

int main()
{
    cin >> s;
    cin >> type;
    if(!type) s = change(s);
    cin >> t;
    while(t --)
    {
        string str;
        cin >> str;
        if(!type && change(str).find(s) != -1) cout << str << endl;
        else if(type && str.find(s) != -1) cout << str << endl;
    }
    return 0;
}

python

s = input()
t = int(input())
def change(s):
    res = ''
    for i in s:
        if ord(i) <= ord('Z'):
            res += chr(ord(i) + ord('a') - ord('A'))
        else:
            res += i
    return res

if t == 0:
    s = change(s)
for _ in range(int(input())):
    w = input()
    if t == 0:
        if s in change(w):
            print(w)
    else:
        if s in w:
            print(w)

 第四题:最优配餐

栋栋最近开了一家餐饮连锁店,提供外卖服务。

随着连锁店越来越多,怎么合理的给客户送餐成为了一个急需解决的问题。

栋栋的连锁店所在的区域可以看成是一个 n×n的方格图(如下图所示),方格的格点上的位置上可能包含栋栋的分店(绿色标注)或者客户(蓝色标注),有一些格点是不能经过的(红色标注)。

方格图中的线表示可以行走的道路,相邻两个格点的距离为 1。

栋栋要送餐必须走可以行走的道路,而且不能经过红色标注的点。

送餐的主要成本体现在路上所花的时间,每一份餐每走一个单位的距离需要花费 1 块钱。

每个客户的需求都可以由栋栋的任意分店配送,每个分店没有配送总量的限制。

现在你得到了栋栋的客户的需求,请问在最优的送餐方式下,送这些餐需要花费多大的成本。

输入格式

输入的第一行包含四个整数 n,m,k,d,分别表示方格图的大小、栋栋的分店数量、客户的数量,以及不能经过的点的数量。

接下来 m 行,每行两个整数 xi,yi,表示栋栋的一个分店在方格图中的横坐标和纵坐标。

接下来 k 行,每行三个整数 xi,yi,ci,分别表示每个客户在方格图中的横坐标、纵坐标和订餐的量。(注意,可能有多个客户在方格图中的同一个位置)

接下来 d 行,每行两个整数,分别表示每个不能经过的点的横坐标和纵坐标。

输出格式

输出一个整数,表示最优送餐方式下所需要花费的成本。

数据范围

前 30% 的评测用例满足:1≤n≤20。
前 60% 的评测用例满足:1≤n≤100。
所有评测用例都满足:1≤n≤1000,1≤m,k,d≤n2,1≤xi,yi≤n。
可能有多个客户在同一个格点上。
每个客户的订餐量不超过 1000,每个客户所需要的餐都能被送到。

输入样例:

10 2 3 3
1 1
8 8
1 5 1
2 3 3
6 7 2
1 2
2 2
6 8

输出样例:

29

 

 

 解题思路:使用bfs进行洪泛操作,对于每一个可以送出外卖的点加入队列,然后求出每一个可以到达的点的最短距离,最终成本就是所有的需要被送餐的点乘以需要的餐品的总数求和,即可得到答案。

以下是代码:

c++

#include <iostream>
#include <cstring>
#include <algorithm>
#include <queue>

#define x first
#define y second

using namespace std;

typedef long long LL;
typedef pair<int, int> PII;
const int N = 1010;

int n, m, k, d;
bool g[N][N];
int dist[N][N];
queue<PII> q;
struct Target
{
    int x, y, c;
}tg[N * N];

void bfs()
{
    int dx[] = {-1, 0, 1, 0}, dy[] = {0, 1, 0, -1};
    while (q.size())
    {
        auto t = q.front();
        q.pop();

        for (int i = 0; i < 4; i ++ )
        {
            int x = t.x + dx[i], y = t.y + dy[i];
            if (x < 1 || x > n || y < 1 || y > n || g[x][y]) continue;
            if (dist[x][y] > dist[t.x][t.y] + 1)
            {
                dist[x][y] = dist[t.x][t.y] + 1;
                q.push({x, y});
            }
        }
    }
}

int main()
{
    scanf("%d%d%d%d", &n, &m, &k, &d);
    memset(dist, 0x3f, sizeof dist);
    while (m -- )
    {
        int x, y;
        scanf("%d%d", &x, &y);
        dist[x][y] = 0;
        q.push({x, y});
    }

    for (int i = 0; i < k; i ++ )
        scanf("%d%d%d", &tg[i].x, &tg[i].y, &tg[i].c);

    while (d -- )
    {
        int x, y;
        scanf("%d%d", &x, &y);
        g[x][y] = true;
    }
    bfs();

    LL res = 0;
    for (int i = 0; i < k; i ++ )
        res += dist[tg[i].x][tg[i].y] * tg[i].c;
    printf("%lld\n", res);
    return 0;
}

 python

太慢了没过,还是使用c++

 第五题:拼图

给出一个 n×m 的方格图,现在要用如下 L 型的积木拼到这个图中,使得方格图正好被拼满,请问总共有多少种拼法。

其中,方格图的每一个方格正好能放积木中的一块。

积木可以任意旋转。

输入格式

输入的第一行包含两个整数 n,m,表示方格图的大小。

输出格式

输出一行,表示可以放的方案数,由于方案数可能很多,所以请输出方案数除以 1e9+7的余数。

数据范围

在评测时将使用 10 个评测用例对你的程序进行评测。
评测用例 1 和 2 满足:1≤n≤30,m=2。
评测用例 3 和 4 满足:1≤n,m≤6。
评测用例 5 满足:1≤n≤100,1≤m≤6。
评测用例 6 和 7 满足:1≤n≤1000,1≤m≤6。
评测用例 8、9 和 10 满足:1≤n≤1e15,1≤m≤7。

输入样例:

6 2

输出样例:

4

样例解释

四种拼法如下图所示:

 解题思路:

前后挨着的两列摆放有对应关系,我们可以用二进制位表示同一列各位的填充状态:1填充,0未填充
f[i][j], i 表示列号,j表示当前列的填充状态,f[i][j]表示方案数
f[i][0] = f[i-1][0]*w[0][0] + f[i-1][1]*w[1][0] + f[i-1][2] * w[2][0] +...+ f[i-1][2^m - 1]*w[2^m -1][0]
w矩阵是记录状态转移方案的矩阵,w[k][b]表示由相邻两列i, i+1 ,列i状态k转换到列i+1状态b的排布方案数
F[i] = {f[i][0],f[i][1],...,f[i][2^m - 1]}
F[i+1] = {f[i+1][0],f[i+1][1],...,f[i+1][2^m - 1]} 
f[i+1][0] = f[i][0]*w[0][0] + f[i][1] * w[1][0]+...+ f[i][2^m -1] * w[2^m -1][0]
f[i+1][1] = f[i][0]*w[0][1] + f[i][1] * w[1][1]+...+ f[i][2^m -1] * w[2^m -1][1]
...
f[i+1][2^m -1] = f[i][0]*w[0][2^m -1] + f[i][1] * w[1][2^m -1]+...+ f[i][2^m -1] * w[2^m -1][2^m -1]
--> F[i+1] = F[i] * w
--> F[n] = F[n-1]* w = F[n-2]*w*w = ... = F[0]*w^n
F[0]只有一个合法状态就是f[0][2^m - 1] = 1,即第0列全部排满只有一种方案,其余方案数均为0

(学习学习)

以下是代码:

c++

#include<iostream>
#include<algorithm>
#include<cstring>

using  namespace std;

const int N = 130, mod = 1e9+7;

typedef long long LL;

int w[N][N];
LL n;
int m;
void dfs(int x,int y,int u)
{
    if(u == m)  w[x][y]++;  // 枚举完x列的各个位,对应的方案数+1
    if(x >> u & 1)  return dfs(x,y,u+1); // x列第u位是非空状态,直接在看下一位
    else
    {
        if(u && !(y >> u & 1) && !(y >> u - 1 & 1))  // 摆法1:当y列的 第u 和 u - 1位为空
            dfs(x, y + (1 << u ) + (1 << u - 1), u + 1);
        if(u + 1 < m && !(y >> u & 1) && !(y >> u + 1 & 1)) //摆法2:当y列的第u 和 u+1 位为空
            dfs(x, y + (1 << u ) + (1 << u + 1), u + 1);
        if(u + 1 <m && !(x >> u + 1 & 1))  // 列x的第u+1位也为空
        {
            if(!(y << u + 1 & 1))  dfs(x, y + 1<<u+1, u + 2); //摆法3,y的第u+1位为空
            if(!(y << u & 1))  dfs(x, y + 1 << u, u + 2);  //摆法4,y的第u位为空
        }
    }
}

void mulit(int c[][N], int a[][N],int b[][N])
{
    static int tmp[N][N];
    memset(tmp,0,sizeof tmp);
    for(int i=0; i< 1<<m; i++)
        for(int j = 0; j < 1<<m; j++)
            for(int k = 0; k < 1<<m; k++)
                tmp[i][j] = (tmp[i][j] + (LL)a[i][k] * b[k][j]) % mod;  //矩阵乘法
    memcpy(c,tmp,sizeof tmp);
}

int main()
{
    cin >> n >> m;
    for(int i=0; i< 1 <<m ; i++)
        dfs(i,0,0);

    int res[N][N] = {0}; //F
    res[0][(1 << m )-1] = 1;
    while(n)
    {
        if(n & 1)  mulit(res,res,w);
        mulit(w,w,w);
        n >>= 1;
    }
    cout << res[0][(1 << m) - 1] << endl;  //只有第一行是我们要的结果,所以是res[0],
    return 0;

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/729802.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

华为OD计算工时python脚本

前言 刚入职不知道工时要平均每天满8小时&#xff0c;并且看不到每天的实际工时&#xff0c;一气之下花了一个中午写了个脚本计算每天的工时&#xff0c;分享一下&#xff0c;不同地区的兄弟需要修改一下午休和晚饭时间才能使用。 文件位置 把welink上 上下班时间输入work.c…

支持向量机推导之r||w||=1的限制转化

支持向量机推导之r||w||1的限制转化 很多同学肯定是学过支持向量机的&#xff0c;也可能大致的理解了支持向量机这个算法&#xff0c;我想大部分人在学习这个算法的时候&#xff0c;对于推导过程有一步应该是不太理解。 我先简要介绍一下SVM,SVM的核心思想在于找到一个多维空间…

getCurrentInstance

https://blog.csdn.net/m0_46318298/article/details/130726043 注&#xff1a;$是在vue中所有实例中都可用的一个简单约定&#xff0c;这样做会避免和已被定义的数据&#xff0c;方法&#xff0c;计算属性产生冲突。

Leetcode-每日一题【203.移除链表元素】

题目 给你一个链表的头节点 head 和一个整数 val &#xff0c;请你删除链表中所有满足 Node.val val 的节点&#xff0c;并返回 新的头节点 。 示例 1&#xff1a; 输入&#xff1a;head [1,2,6,3,4,5,6], val 6输出&#xff1a;[1,2,3,4,5] 示例 2&#xff1a; 输入&#…

nginx白名单配置

在有得项目中&#xff0c;我们会希望端口只有特定的用户可以访问&#xff0c;这时候就需要配置nginx的白名单&#xff0c;接来下展示一下白名单的配置和应用 vi /etc/nginx/nginx.conf server {listen 80;listen [::]:80;server_name _;root /usr/share/…

springboot第29集:springboot项目详细

public static LoginUser getLoginUser()&#xff1a;该行声明了一个公共的静态方法 getLoginUser()&#xff0c;它的返回类型是 LoginUser。try&#xff1a;开始一个 try 块&#xff0c;用于处理接下来的代码中可能发生的异常。return (LoginUser) getAuthentication().getPri…

STL好难(6):queue队列的使用

目录 1.queue的介绍 2.queue的使用&#xff1a; 3.queue的模拟实现&#xff1a; 4.deque的介绍&#xff1a; 5.deque的函数接口和底层原理&#xff1a; 6.deque的优缺点&#xff1a; 1.queue的介绍 queue的文档内容 1. 队列是一种容器适配器&#xff0c;专门用于在FIFO上…

二次-InsCode Stable Diffusion 美图活动一期

模型&#xff1a; AbyssOrangeMix2 - SFW_Soft NSFW_AbyssOrangeMix2_sfw.safetensors 参数配置&#xff1a; 正&#xff1a;Mountains and seas, people 负&#xff1a;NSFW, (worst quality:2), (low quality:2), (normal quality:2), lowres, normal quality, ((monochr…

C# .NET 如何调用 SAP RFC 接口

1.分析传参结构 SAP 传参格式对应 .NET 参数格式 SAP 参数.NET 参数参数类型import(导入)——关联类型为数据元素Param单个变量参数import(导出)——关联类型为结构体Struct结构体tableTable表 下面是 SAP 对应参数类型&#xff1a; 2.web.config 配置 配置文件需要客户端…

Python学习笔记(十六)————异常相关

目录 &#xff08;1&#xff09;异常概念 &#xff08;2&#xff09;异常的捕获 ①异常捕获的原因 ②捕获常规异常 ③捕获指定异常 ④捕获多个异常 ⑤ 捕获异常并输出描述信息 ⑥捕获所有异常 ⑦异常else ⑧异常的finally &#xff08;3&#xff09;异常的传递 &#xff08…

自动化测试 selenium 篇

✏️作者&#xff1a;银河罐头 &#x1f4cb;系列专栏&#xff1a;JavaEE &#x1f332;“种一棵树最好的时间是十年前&#xff0c;其次是现在” 目录 什么是自动化测试&#xff1f;Selenium 介绍Selenium 是什么Selenium 特点工作原理 seleniumJava环境搭建ChromeJava1.下载ch…

uni-app:删除默认title

去除前&#xff1a; 可以看到有两个title 去除后&#xff1a; 可以看出就只有手机顶部的title了 "navigationStyle": "custom",//删除默认title

堆的向上与向下调整

目录 一、堆 1、概念 2、性质 二、向上调整 三、向下调整 四、建堆的比较 1.向上调整建堆 2.向下调整建堆 3.比较 五、总结 一、堆 1、概念 如果有一个关键码的集合K {k0k1&#xff0c;k2&#xff0c;…kn-1}&#xff0c;把它的所有元素按完全二叉树的顺序存储方式存…

怎么学习PHP错误处理和调试? - 易智编译EaseEditing

学习PHP错误处理和调试技术可以通过以下步骤&#xff1a; 理解错误类型&#xff1a; 了解PHP中常见的错误类型&#xff0c;如语法错误、运行时错误和逻辑错误等。学习它们的特点和常见原因&#xff0c;以便更好地定位和解决问题。 错误报告设置&#xff1a; 在开发环境中&am…

【Java基础学习打卡14】Java注释

目录 前言一、什么是注释二、注释的重要性三、单行、多行注释1.单行注释2.多行注释 四、文档注释1.文档注释2.JDK官网文档3.javadoc生成文档 五、注释建议总结 前言 本文介绍Java注释&#xff0c;它是我们在Java编程中必不可少的。Java注释有单行注释、多行注释和文档注释。对…

BUUCTF Web CyberPunk WriteUp

想直接查看payload的点这里 前言 二次注入&#xff08;Second-Order Injection&#xff09;是指攻击者在应用程序中注入恶意数据&#xff0c;然后在稍后的操作或不同的上下文中再次使用该恶意数据&#xff0c;导致安全漏洞。它通常发生在数据库查询、数据导出、报告生成等过程…

基于springboot博客论坛系统设计与实现(源码+文档LW+数据库+报告)

HBLOG 是一个博客论坛网站&#xff0c;分为游客端和管理员端。游客端主要有注册登录&#xff0c;查看文章&#xff0c;发表撰写文章&#xff0c;管理自己的文章&#xff0c;评论文章等功能&#xff1b;而管理员端主要有登录&#xff0c;查看近期数据&#xff0c;查看日志&#…

如何做好迭代回顾 2/4

事故根因分析&#xff1a;上集 北京某软件开发公司&#xff0c;专门为电信供应商做定制软件开发&#xff0c;比如发短信做些推广活动等。公司希望做过程改进&#xff0c;我首次与公司老板访谈&#xff1a; 我&#xff1a;过程改进主要帮助管理层更好达到公司业务目标。你们自己…

365天深度学习训练营-第T5周:运动鞋品牌识别

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 我的环境&#xff1a; 语言环境&#xff1a;Python3.10.7编译器&#xff1a;VScode深度学习环境&#xff1a;TensorFlow2 一、前期工作&#xff1a; 1、导入…

【活动】如何在工作中管理情绪

写在前面 近期发生的新闻热点再度引发公众对稳定情绪和心理健康的关注。有时候我们遇到的最大的敌人&#xff0c;不是运气也不是能力&#xff0c;而是失控的情绪和口无遮拦的自己。如何在工作中保持稳定的情绪&#xff1f;谈谈我的看法。 愤怒的危害 说到愤怒这种情绪&#xf…