c语言:插入排序,二维数组

插入排序

思路:向有序的区域中插入一个新元素,仍保持有序。

  1. 初始时,0索引的元素是有序的
  2. 从1索引的元素开始插入 a. 比较当前要插入的元素key和有序区域的最后一个元素 i:如果当前的key要大,就直接插入 ii:如果当前的key要小,就在有序区域中找到一个合适的位置插入 (一边找,一边向后赋值)
c 复制代码
#include <stdio.h>
//插入排序
void sort_insert(int arr[], int len){
for (int i = 1; i < len; i++)
{
    int j = i;
    int key = arr[j];
    while (j > 0 && key < arr[j - 1]){
        arr[j] = arr[j - 1];
        j--;
    }
    arr[j] = key;
}
}
int main()
{
    int arr[10] = {10, 3, 2, 5, 7, 2, 9, 2, 1, 8};
    int len = sizeof(arr) / sizeof(arr[0]);
    sort_insert(arr, len);
    for (int i = 0; i <= len - 1; i++)
    {
        printf("%d ", arr[i]);
    }
    return 0;
}

二维数组

  1. 也称为矩阵
  2. 二维数组打印 下面的%4d是指4位数,可以让矩阵对齐
c 复制代码
#include <stdio.h>
int main(){
    int arr[3]={1,2,3};//一维
    int arr2[2][3]={{1,2,3},{4,5,6}};//二维
    printf("%d\n",arr2[1][2]);
    for(int i=0;i<2;i++){//行
        for(int j=0;j<3;j++){//列
            printf("%4d ",arr2[i][j]);
        }
        printf("\n");
    }
    arr2[0][0]=10;
    printf("%d\n",arr2[0][0]);
    return 0;
}
  1. 二维数组翻转
c 复制代码
#include <stdio.h>
void swap(int arr[][3], int m, int n)
{
    for(int i = 0; i <m;i++){
        for(int j = 0; j < n; j++){
            if(j>i){
            int temp = arr[i][j];
            arr[i][j] = arr[j][i];
            arr[j][i] = temp;
        }
        }
    }
}
int main()
{
    int arr[3][3] = {{1, 2, 3}, {4, 5, 6}, {7, 8, 9}};
    swap(arr, 3, 3);
    for (int i = 0; i < 3; i++)
    {
        for (int j = 0; j < 3; j++)
        {
            printf("%4d ", arr[i][j]);
        }
        printf("\n");
    }
    return 0;
}

矩阵转置

c 复制代码
#include <stdio.h>
int main()
{
    int arr[2][3] = {{1, 2, 3},{4, 5, 6}};
    int arr2[3][2];
    for (int i = 0; i < 3; i++) {
        for (int j = 0; j < 2; j++)
        {
            arr2[i][j] = arr[j][i];
        }
    }
    for (int i = 0; i < 3; i++)
    {
        for (int j = 0; j < 2; j++)
        {
            printf("%4d ", arr2[i][j]);
        }
        printf("\n");
    }
    return 0;
}

扫雷

c 复制代码
#include <stdio.h>
int main()
{
    char arr1[4][4] = {{'*', '.', '.', '.'}, {'.', '.', '*', '.'}, {'.', '.', '.', '.'}, {'*', '.', '.', '.'}};
    char arr2[4][4];
    for (int i = 0; i < 4; i++)
    {
        for (int j = 0; j < 4; j++)
        {
            if (arr1[i][j] == '*')
            {
                arr2[i][j] = '*';
            }
            else
            {
                int count = 0;
                for (int x = i - 1; x <= i + 1; x++)
                {
                    for (int y = j - 1; y <= j + 1; y++)
                    {
                        if (x >= 0 && x < 4 && y >= 0 && y < 4 && arr1[x][y] == '*')
                        {
                            if (arr1[x][y] == '*')
                            {
                                count++;
                            }
                        }
                    }
                }
                arr2[i][j] = count + '0';
            }
        }
    }
    for (int i = 0; i < 4; i++)
    {
        for (int j = 0; j < 4; j++)
        {
            printf("%c ", arr2[i][j]);
        }
        printf("\n");
    }
    return 0;
}
相关推荐
Dillon Dong1 小时前
STM32嵌入式:使用 MT29F8G08ABACAWP NAND 的FLASH全面指南
c语言·stm32
zhongvv2 小时前
对单片机C语言指针的一些理解
c语言·数据结构·单片机·指针·汇编语言
朔北之忘 Clancy3 小时前
2025 年 9 月青少年软编等考 C 语言一级真题解析
c语言·开发语言·c++·学习·数学·青少年编程·题解
你怎么知道我是队长4 小时前
C语言---缓冲区
c语言·开发语言
不爱吃糖的程序媛5 小时前
OpenHarmony 通用C/C++三方库 标准化鸿蒙化适配
c语言·c++·harmonyos
朔北之忘 Clancy6 小时前
2020 年 6 月青少年软编等考 C 语言二级真题解析
c语言·开发语言·c++·学习·青少年编程·题解·尺取法
HABuo7 小时前
【Linux进程(五)】进程地址空间深入剖析-->虚拟地址、物理地址、逻辑地址的区分
linux·运维·服务器·c语言·c++·后端·centos
AuroraWanderll7 小时前
类和对象(六)--友元、内部类与再次理解类和对象
c语言·数据结构·c++·算法·stl
无限进步_7 小时前
【C语言&数据结构】另一棵树的子树:递归思维的双重奏
c语言·开发语言·数据结构·c++·算法·github·visual studio
不爱吃糖的程序媛7 小时前
OpenHarmony跨端生态适配全指南|Flutter/RN/三方库/C/C++/仓颉 鸿蒙化最佳实践
c语言·c++·flutter