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

蛇形填充数组

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

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;
}
相关推荐
JXL18602 小时前
Dynamic programming
算法
blackicexs2 小时前
第四周第四天
数据结构·c++·算法
TracyCoder1232 小时前
LeetCode Hot100(46/100)——74. 搜索二维矩阵
算法·leetcode·矩阵
foundbug9992 小时前
果蝇优化算法(FOA)详解:原理、实现与应用
算法
游乐码2 小时前
c#递归函数
算法·c#
Pluchon2 小时前
硅基计划4.0 算法 简单实现B树
java·数据结构·b树·算法·链表
im_AMBER2 小时前
Leetcode 119 二叉树展开为链表 | 路径总和
数据结构·学习·算法·leetcode·二叉树
Eloudy2 小时前
SuiteSparse 的 README
人工智能·算法·机器学习·hpc
知无不研3 小时前
c++的设计模式(常用)
c++·观察者模式·单例模式·设计模式·简单工厂模式