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

蛇形填充数组

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

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;
}
相关推荐
一只数据集11 小时前
全尺寸人形机器人灵巧手力觉触觉数据集-2908条ROSbag数据覆盖14大应用场景深度解析
大数据·人工智能·算法·机器人
罗西的思考12 小时前
【GUI-Agent】阿里通义MAI-UI 代码阅读(2)--- 实现
人工智能·算法·机器学习
流年如夢12 小时前
单链表进阶版 -->双向链表
数据结构·链表
刀法如飞13 小时前
TypeScript 数组去重的 20 种实现方式,哪一种你还不知道?
前端·javascript·算法
流年如夢14 小时前
单链表 -->增、删、查、改等详细操作
c语言·数据结构
tankeven14 小时前
C++ 智能指针
c++
sali-tec14 小时前
C# 基于OpenCv的视觉工作流-章66-直线夹角
图像处理·人工智能·opencv·算法·计算机视觉
AC赳赳老秦14 小时前
接口测试自动化:用 OpenClaw 对接 Postman,实现批量回归测试、测试报告自动生成与推送
java·人工智能·python·算法·elasticsearch·deepseek·openclaw
_风满楼14 小时前
TDD实战-会议室冲突检测的红绿重构循环
前端·javascript·算法
pq21715 小时前
java实现遗传算法
算法