每日两题day59

今天你AC了吗?

每日两题day59


一、基础题

题目:P1421 小玉买文具 - 洛谷

思路:

涉及多种进制的题目都可以全部拆成最小的单位再处理。

代码:

cpp 复制代码
#include <bits/stdc++.h>
int main() {
    int a, b, sum = 0;
    std::cin >> a >> b;
    sum = a * 10 + b;
    std::cout << (sum / 19);
    return 0;
}

二、提高题

题目:P2615 [NOIP 2015 提高组] 神奇的幻方 - 洛谷

思路:

纯模拟,按题目来的写判别函数就好了

代码:

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

int n = 40, i = 1;
std::vector<std::vector<int>> a(n, std::vector<int>(n));

std::pair<int, int> next(std::pair<int, int> b) {
    if (b.first == 0 && b.second != n - 1) {
        return {n - 1, b.second + 1};
    }
    if (b.second == n - 1 && b.first != 0) {
        return {b.first - 1, 0};
    }
    if (b.first == 0 && b.second == n - 1) {
        return {1, n - 1};
    }
    if (b.first - 1 >= 0 && b.second + 1 < n && a[b.first - 1][b.second + 1] == 0) {
        return {b.first - 1, b.second + 1};
    } else {
        return {b.first + 1, b.second};
    }
}

int main() {
    std::pair<int, int> before;
    std::cin >> n;

    a[0][n / 2] = 1;
    before = {0, n / 2};
    while (++i <= n * n) {
        before = next(before);
        a[before.first][before.second] = i;
    }
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < n; j++) {
            std::cout << a[i][j] << " ";
        }
        std::cout << "\n";
    }
    return 0;
}
相关推荐
IronMurphy2 小时前
【算法四十三】279. 完全平方数
算法
墨染天姬2 小时前
【AI】Hermes的GEPA算法
人工智能·算法
papership3 小时前
【入门级-数据结构-3、特殊树:完全二叉树的数组表示法】
数据结构·算法·链表
smj2302_796826523 小时前
解决leetcode第3911题.移除子数组元素后第k小偶数
数据结构·python·算法·leetcode
山甫aa3 小时前
差分数组 ----- 从零开始的数据结构
数据结构
早日退休!!!3 小时前
《数据结构选型指南》笔记
数据结构·数据库·oracle
Beginner x_u4 小时前
链表专题:JS 实现原理与高频算法题总结
javascript·算法·链表
丑八怪大丑4 小时前
Java数据结构与集合源码
数据结构
c++之路5 小时前
C++信号处理
开发语言·c++·信号处理
_深海凉_7 小时前
LeetCode热题100-寻找两个正序数组的中位数
算法·leetcode·职场和发展