笔试——Day47

第一题

题目

BC138 矩阵转置

在这里插入图片描述

思路

模拟 : 坐标转换

代码

#include <iostream>
using namespace std;


int arr[15][15];
int res[15][15];
int n, m;

int main() 
{
    cin >> n >> m;
    for(int i = 1; i <= n; i++)
    {
        for(int j = 1; j <= m; j++)
        {
            cin >> arr[i][j];
            res[j][i] = arr[i][j];
        }
    }

    for(int i = 1; i <= m; i++)
    {
        for(int j = 1;j <= n; j++)
        {
            cout << res[i][j] << " ";
        }
        cout << endl;
    }

    return 0;
}
// 64 位输出请用 printf("%lld")

第二题

题目

四个选项

在这里插入图片描述

思路

DFS 枚举12个位置可能得4个选项

注意剪支:

  • 判断当前选项是否还有剩余;
  • 判断当前选项是否和前方选项相同;

代码

#include <iostream>
#include <vector>

using namespace std;

int arr[6];
bool same[13][13]; // i, j 的答案相同
int res;
vector<int> path; // 记录路径⾥⾯选了哪些选项

bool isSame(int pos, int cur)// pos 位置填 cur ,是否符合要求
{
    for(int i = 1; i < pos; i++)
    {
        if(same[pos][i] && path[i] != cur) return false;
    }
    return true;
    
}

void dfs(int pos)
{
    if(pos > 12)
    {
        res++;
        return ;
    }
    
    for(int i = 1; i <= 4; i++)
    {
        if(arr[i] == 0) continue; // 选项已经用完了
        
        if(!isSame(pos, i)) continue; 
        
        arr[i]--;
        path.push_back(i);
        dfs(pos + 1);
        path.pop_back();
        arr[i]++;
    }
    
}

int main()
{
    for(int i = 1; i <= 5; i++) cin >> arr[i];
    
    int t = arr[5];
    while(t--)
    {
        int x, y;
        cin >> x >> y;
        same[x][y] = same[y][x] = true;
    }
    
    path.push_back(0); // 填 0 位置(类似于占位符)
    dfs(1);
    
    cout << res <<endl;
    
    
    return 0;
}

第三题

题目

42. 接雨水
在这里插入图片描述

思路

利用两个数组,来统计,当前位置左右的最高柱子;
则当前位置能容纳的水的数量,等于 当前位置左右最高柱子的最小值间当前位置

代码

class Solution {
public:
    int trap(vector<int>& height) {
        int n = height.size();
        vector<int> left(n);
        auto right = left;

        left[0] = height[0];
        for(int i = 1; i < n; i++)
        {
            left[i] = max(left[i - 1], height[i]);
        }

        right[n - 1] = height[n - 1];
        for(int i = n - 2; i >= 0; i--)
        {
            right[i] = max(right[i + 1], height[i]);
        }

        int res = 0;
        for(int i = 0; i < n; i++)
        {
            res += min(left[i], right[i]) - (height[i]);
        }
        return res;
    }
};
你好!对于成都笔试中的PL/SQL准备,我可以为你提供一些指导和建议。PL/SQL是一种过程式编程语言,用于Oracle数据库的开发和管理。下面是一些可以帮助你准备PL/SQL笔试的建议: 1. 理解PL/SQL语法:掌握PL/SQL的基本语法结构,包括变量声明、条件语句、循环语句、游标和异常处理等。熟悉这些基础知识对于理解和编写PL/SQL代码至关重要。 2. 学习SQL语句:PL/SQL是建立在SQL语言基础上的,所以熟悉SQL语句也是非常重要的。掌握SQL查询、插入、更新和删除等基本操作,以及表连接、子查询和聚合函数等高级查询技巧。 3. 理解存储过程和函数:PL/SQL的核心概念是存储过程和函数。了解它们的定义、调用和使用方法,以及参数传递、返回值和异常处理等方面的知识。 4. 掌握PL/SQL的高级特性:学习PL/SQL的高级特性,如游标、触发器和包等。了解它们的用途和使用方法,以及与数据库交互和数据处理的相关技巧。 5. 多做练习题和项目实践:通过做一些练习题和实际项目,加深对PL/SQL的理解和应用能力。可以使用在线编程平台或者自己搭建一个本地的Oracle数据库环境。 6. 阅读相关文档和教程:阅读Oracle官方文档和一些相关的教程和书籍,可以帮助你更全面地了解和掌握PL/SQL的知识。 希望以上建议对你有所帮助!祝你在成都笔试中取得好成绩!如果你还有其他问题,可以继续向我提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值