蛇形填充数组 与 查找最接近的元素

蛇形填充数组

按副对角线分为两个三角处理:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){
    int n;
    cin >> n;
    
    int arr[n][n];
    int num = 1;
    // 上半三角(包括主对角线)
    for (int k = 0; k < n; k++) {
        if (k % 2 == 0) { // 偶数k:从下到上(行减,列加)
            for (int i = k; i >= 0; i--) arr[i][k - i] = num++;
        } else { // 奇数k:从上到下(行加,列减)
            for (int i = 0; i <= k; i++) arr[i][k - i] = num++;
        }
    }

    // 下半三角(不包括主对角线)
    for (int k = n; k <= 2 * (n - 1); k++) {
        if (k % 2 == 0) { // 偶数k:从下到上
            for (int i = n - 1; i >= k - (n - 1); i--) arr[i][k - i] = num++;
        } else { // 奇数k:从上到下
            for (int i = k - (n - 1); i <= n - 1; i++) arr[i][k - i] = num++;
        }
    }

    // 输出
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < n; j++) {
            cout << arr[i][j] << " ";
        }
        cout << endl;
    }

    return 0;
}

查找最接近的元素

二分查找查找其索引,按索引比较其两个。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){
    int n,m;
    cin >> n;
    vector<int> arr(n);
    for(int i = 0;i<n;i++) cin >> arr[i];
    
    cin >> m;
    while(m--){
        int x;
        cin >> x;
        // 二分查找下界
        int pos = lower_bound(arr.begin(), arr.end(), x) - arr.begin();

        int ans;
        if (pos == 0) ans = arr[0];
        else if (pos == n) ans = arr[n - 1];
        else {// 比较 a[pos] 和 a[pos-1] 哪个更接近 x
            if (arr[pos] - x < x - arr[pos - 1]) ans = arr[pos];
            else ans = arr[pos - 1]; // 相等时取较小的(即左边的)
        }
        cout << ans << endl;
    }
    return 0;
}
相关推荐
Peter·Pan爱编程6 分钟前
14. Lambda 表达式:随手可写的函数对象
c++·算法·ai编程
-To be number.wan6 分钟前
算法日记 | 暴力枚举
学习·算法
s_w.h22 分钟前
【 linux 】动静态库的制作
linux·运维·服务器·算法·bash
不想写代码的星星1 小时前
从分支预测角度看 C++:为什么你的热循环慢得离谱?
c++
过期动态1 小时前
【LeetCode 热题 100】接雨水
java·数据结构·算法·leetcode·职场和发展
春日见1 小时前
5分钟入门强化学习之动态规划算法与实现
大数据·人工智能·python·算法·机器学习·计算机视觉
郝学胜-神的一滴1 小时前
Qt 高级开发 018:复刻经典登录界面布局与窗口美化全解析
开发语言·c++·qt·程序人生·用户界面
scx_link1 小时前
线性回归的总结:
算法·机器学习·线性回归
郝亚军1 小时前
IEEE 754 单精度浮点的SEM表示
开发语言·c++·算法
青山师1 小时前
动态规划算法深度解析:从状态转移方程到工业级优化
数据结构·算法·面试·动态规划·代理模式·java面试