C语言作为一门历史悠久且应用广泛的编程语言,至今仍被广泛应用于系统编程、嵌入式系统、操作系统等领域。学习C语言不仅能够帮助你理解计算机的工作原理,还能提高你的编程能力。下面,我将为你介绍10个实战案例,帮助你从不同角度深入理解和掌握C语言编程。

1. 控制台应用程序

案例描述:编写一个简单的控制台应用程序,实现用户输入姓名和年龄,程序输出用户信息。

学习目标:了解C语言的输入输出函数,如printfscanf

#include <stdio.h>

int main() {
    char name[100];
    int age;

    printf("请输入你的姓名:");
    scanf("%99s", name);
    printf("请输入你的年龄:");
    scanf("%d", &age);

    printf("你的姓名是:%s,年龄是:%d\n", name, age);

    return 0;
}

2. 计算器程序

案例描述:编写一个简单的计算器程序,实现加、减、乘、除运算。

学习目标:掌握C语言中的运算符和条件语句。

#include <stdio.h>

int main() {
    double num1, num2;
    char operator;

    printf("请输入两个数字(用空格隔开):");
    scanf("%lf %lf", &num1, &num2);
    printf("请输入运算符(+、-、*、/):");
    scanf(" %c", &operator); // 注意前面的空格,用于跳过前面的换行符

    switch (operator) {
        case '+':
            printf("结果是:%lf\n", num1 + num2);
            break;
        case '-':
            printf("结果是:%lf\n", num1 - num2);
            break;
        case '*':
            printf("结果是:%lf\n", num1 * num2);
            break;
        case '/':
            if (num2 != 0) {
                printf("结果是:%lf\n", num1 / num2);
            } else {
                printf("除数不能为0\n");
            }
            break;
        default:
            printf("无效的运算符\n");
    }

    return 0;
}

3. 字符串处理

案例描述:编写一个程序,实现字符串的复制、连接和查找子字符串。

学习目标:了解C语言中的字符串处理函数,如strcpystrcatstrstr

#include <stdio.h>
#include <string.h>

int main() {
    char source[100], destination[200];
    char substring[] = "编程";

    printf("请输入源字符串:");
    scanf("%99s", source);
    printf("复制字符串到目标字符串:\n");
    strcpy(destination, source);
    printf("目标字符串:%s\n", destination);

    printf("连接字符串:\n");
    strcat(destination, "世界");
    printf("连接后的字符串:%s\n", destination);

    printf("查找子字符串:%s\n", strstr(destination, substring));
    return 0;
}

4. 数组操作

案例描述:编写一个程序,实现数组的排序、查找和统计。

学习目标:掌握C语言中的数组操作,如排序、查找和统计。

#include <stdio.h>

void sort(int arr[], int n) {
    int i, j, temp;
    for (i = 0; i < n - 1; i++) {
        for (j = 0; j < n - i - 1; j++) {
            if (arr[j] > arr[j + 1]) {
                temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
}

int main() {
    int arr[] = {5, 2, 9, 1, 5, 6};
    int n = sizeof(arr) / sizeof(arr[0]);
    int i, search, count = 0;

    sort(arr, n);
    printf("排序后的数组:\n");
    for (i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");

    printf("请输入要查找的数字:");
    scanf("%d", &search);
    for (i = 0; i < n; i++) {
        if (arr[i] == search) {
            count++;
        }
    }
    if (count > 0) {
        printf("数字%d在数组中出现了%d次\n", search, count);
    } else {
        printf("数字%d不在数组中\n", search);
    }

    return 0;
}

5. 函数调用

案例描述:编写一个程序,实现两个函数:一个用于计算阶乘,另一个用于计算斐波那契数列。

学习目标:了解C语言中的函数定义和调用。

#include <stdio.h>

int factorial(int n) {
    if (n == 0) {
        return 1;
    } else {
        return n * factorial(n - 1);
    }
}

int fibonacci(int n) {
    if (n <= 1) {
        return n;
    } else {
        return fibonacci(n - 1) + fibonacci(n - 2);
    }
}

int main() {
    int n;

    printf("请输入一个数字:");
    scanf("%d", &n);

    printf("阶乘:%d\n", factorial(n));
    printf("斐波那契数列:%d\n", fibonacci(n));

    return 0;
}

6. 指针操作

案例描述:编写一个程序,实现指针的交换、复制和排序。

学习目标:掌握C语言中的指针操作。

#include <stdio.h>

void swap(int *a, int *b) {
    int temp = *a;
    *a = *b;
    *b = temp;
}

void sort(int *arr[], int n) {
    int i, j, temp;
    for (i = 0; i < n - 1; i++) {
        for (j = 0; j < n - i - 1; j++) {
            if (*(arr[j]) > *(arr[j + 1])) {
                swap(arr[j], arr[j + 1]);
            }
        }
    }
}

int main() {
    int arr[] = {5, 2, 9, 1, 5, 6};
    int n = sizeof(arr) / sizeof(arr[0]);
    int *ptr_arr[n];

    for (int i = 0; i < n; i++) {
        ptr_arr[i] = &arr[i];
    }

    sort(ptr_arr, n);

    printf("排序后的数组:\n");
    for (int i = 0; i < n; i++) {
        printf("%d ", *ptr_arr[i]);
    }
    printf("\n");

    return 0;
}

7. 文件操作

案例描述:编写一个程序,实现文件的创建、读取和写入。

学习目标:了解C语言中的文件操作函数,如fopenfprintffclose

#include <stdio.h>

int main() {
    FILE *fp;
    char filename[] = "example.txt";
    char data[] = "这是一段测试数据。\n";

    // 创建文件
    fp = fopen(filename, "w");
    if (fp == NULL) {
        printf("无法创建文件:%s\n", filename);
        return 1;
    }
    fprintf(fp, "%s", data);
    fclose(fp);

    // 读取文件
    fp = fopen(filename, "r");
    if (fp == NULL) {
        printf("无法打开文件:%s\n", filename);
        return 1;
    }
    char buffer[100];
    while (fgets(buffer, sizeof(buffer), fp)) {
        printf("%s", buffer);
    }
    fclose(fp);

    return 0;
}

8. 动态内存分配

案例描述:编写一个程序,实现动态内存分配和释放。

学习目标:了解C语言中的动态内存分配函数,如mallocfree

#include <stdio.h>
#include <stdlib.h>

int main() {
    int *arr;
    int n, i;

    printf("请输入数组的大小:");
    scanf("%d", &n);

    // 动态分配内存
    arr = (int *)malloc(n * sizeof(int));
    if (arr == NULL) {
        printf("内存分配失败\n");
        return 1;
    }

    // 输入数组元素
    printf("请输入数组元素:\n");
    for (i = 0; i < n; i++) {
        scanf("%d", &arr[i]);
    }

    // 打印数组元素
    printf("数组元素:\n");
    for (i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");

    // 释放内存
    free(arr);

    return 0;
}

9. 结构体操作

案例描述:编写一个程序,实现结构体的定义、创建和操作。

学习目标:了解C语言中的结构体。

#include <stdio.h>

typedef struct {
    char name[50];
    int age;
    float salary;
} Employee;

int main() {
    Employee emp1, emp2;

    strcpy(emp1.name, "张三");
    emp1.age = 25;
    emp1.salary = 5000.0;

    strcpy(emp2.name, "李四");
    emp2.age = 30;
    emp2.salary = 6000.0;

    printf("员工1:%s,%d岁,%.2f元\n", emp1.name, emp1.age, emp1.salary);
    printf("员工2:%s,%d岁,%s元\n", emp2.name, emp2.age, emp2.salary);

    return 0;
}

10. 链表操作

案例描述:编写一个程序,实现链表的创建、插入、删除和遍历。

学习目标:了解C语言中的链表。

#include <stdio.h>
#include <stdlib.h>

typedef struct Node {
    int data;
    struct Node *next;
} Node;

// 创建链表
Node *createList(int arr[], int n) {
    Node *head = NULL, *tail = NULL, *newNode;
    for (int i = 0; i < n; i++) {
        newNode = (Node *)malloc(sizeof(Node));
        newNode->data = arr[i];
        newNode->next = NULL;
        if (head == NULL) {
            head = newNode;
            tail = newNode;
        } else {
            tail->next = newNode;
            tail = newNode;
        }
    }
    return head;
}

// 插入节点
void insertNode(Node *head, int data) {
    Node *newNode = (Node *)malloc(sizeof(Node));
    newNode->data = data;
    newNode->next = head;
    head = newNode;
}

// 删除节点
void deleteNode(Node *head, int data) {
    Node *temp = head, *prev = NULL;
    while (temp != NULL && temp->data != data) {
        prev = temp;
        temp = temp->next;
    }
    if (temp == NULL) {
        printf("没有找到数据为%d的节点\n", data);
        return;
    }
    if (prev == NULL) {
        head = temp->next;
    } else {
        prev->next = temp->next;
    }
    free(temp);
}

// 遍历链表
void traverseList(Node *head) {
    Node *temp = head;
    while (temp != NULL) {
        printf("%d ", temp->data);
        temp = temp->next;
    }
    printf("\n");
}

int main() {
    int arr[] = {1, 2, 3, 4, 5};
    int n = sizeof(arr) / sizeof(arr[0]);
    Node *head = createList(arr, n);

    printf("原始链表:\n");
    traverseList(head);

    insertNode(head, 6);
    printf("插入节点后的链表:\n");
    traverseList(head);

    deleteNode(head, 3);
    printf("删除节点后的链表:\n");
    traverseList(head);

    return 0;
}

通过以上10个实战案例,相信你已经对C语言编程有了更深入的了解。不断练习和积累经验,你将能够熟练地运用C语言解决各种问题。祝你学习顺利!