数组插入函数c语言实现
时间: 2024-01-07 21:04:04 浏览: 35
以下是一个简单的数组插入函数的C语言实现:
```c
#include <stdio.h>
void insert(int arr[], int n, int pos, int val){
int i;
// 从后往前遍历数组,将每个元素向后移动一位
for(i=n-1;i>=pos;i--){
arr[i+1] = arr[i];
}
// 将新值插入到指定位置
arr[pos] = val;
// 数组长度加1
n++;
}
int main(){
int arr[10] = {1,2,3,4,5};
int n = 5; // 数组长度
int pos = 2; // 插入位置
int val = 10; // 插入值
insert(arr, n, pos, val);
int i;
// 遍历数组
for(i=0;i<n+1;i++){
printf("%d ", arr[i]);
}
return 0;
}
```
这个函数将一个整数数组、数组长度、插入位置和插入值作为参数。它通过将数组中指定位置后面的元素向后移动一位,并将新值插入到指定位置来实现数组插入。最后,它增加了数组长度并返回插入后的数组。
相关问题
插入数组到数据库c语言
在 C 语言中,如果要将数组中的数据插入到数据库中,需要使用数据库的相关 API。以下是一个示例代码,演示如何将一个整数数组插入到 SQLite 数据库中:
```c
#include <stdio.h>
#include <sqlite3.h>
int main(void) {
sqlite3* db;
char* err_msg = 0;
int data[] = {1, 2, 3, 4, 5};
int data_len = sizeof(data) / sizeof(int);
int rc = sqlite3_open("test.db", &db);
if (rc != SQLITE_OK) {
fprintf(stderr, "Cannot open database: %s\n", sqlite3_errmsg(db));
sqlite3_close(db);
return 1;
}
char* sql = "CREATE TABLE IF NOT EXISTS numbers (id INTEGER PRIMARY KEY, value INTEGER);";
rc = sqlite3_exec(db, sql, 0, 0, &err_msg);
if (rc != SQLITE_OK ) {
fprintf(stderr, "SQL error: %s\n", err_msg);
sqlite3_free(err_msg);
sqlite3_close(db);
return 1;
}
for (int i = 0; i < data_len; i++) {
char insert_sql[100];
sprintf(insert_sql, "INSERT INTO numbers (id, value) VALUES (%d, %d);", i, data[i]);
rc = sqlite3_exec(db, insert_sql, 0, 0, &err_msg);
if (rc != SQLITE_OK ) {
fprintf(stderr, "SQL error: %s\n", err_msg);
sqlite3_free(err_msg);
sqlite3_close(db);
return 1;
}
}
sqlite3_close(db);
return 0;
}
```
在这个示例代码中,我们使用了 SQLite 数据库。首先,我们通过 `sqlite3_open` 函数打开数据库连接,然后使用 `sqlite3_exec` 函数执行 SQL 语句。在这里,我们创建了一个名为 `numbers` 的表,包含两个列:`id` 和 `value`。接下来,我们使用循环将数组中的数据逐一插入到数据库中。每次循环,我们使用 `sprintf` 函数生成一个插入语句,然后使用 `sqlite3_exec` 函数执行该语句。
需要注意的是,在实际开发中,我们需要对 SQL 语句进行参数化,以避免 SQL 注入攻击。此处为了简单起见,我们直接将数据插入到 SQL 语句中。
插入排序c语言数组实现
以下是使用C语言实现插入排序的数组代码示例:
```c
#include <stdio.h>
void insertionSort(int arr[], int n) {
int i, key, j;
for (i = 1; i < n; i++) {
key = arr[i];
j = i - 1;
while (j >= 0 && arr[j] > key) {
arr[j + 1] = arr[j];
j = j - 1;
}
arr[j + 1] = key;
}
}
int main() {
int arr[] = {12, 11, 13, 5, 6};
int n = sizeof(arr) / sizeof(arr[0]);
insertionSort(arr, n);
printf("Sorted array: \n"); for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
return 0;
}
```
在这个示例中,我们定义了一个名为`insertionSort`的函数,该函数接受一个整数数组和数组的大小作为参数,并使用插入排序算法对数组进行排序。然后我们在`main`函数中定义了一个整数数组,并将其传递给`insertionSort`函数进行排序。最后,我们打印已排序的数组。