实例1:简单的计算器程序

在C语言中,编写一个简单的计算器程序是学习编程的基础。以下是一个简单的示例:

#include <stdio.h>

int main() {
    char operator;
    double firstNumber, secondNumber;

    printf("Enter an operator (+, -, *, /): ");
    scanf("%c", &operator);

    printf("Enter two operands: ");
    scanf("%lf %lf", &firstNumber, &secondNumber);

    switch (operator) {
        case '+':
            printf("%.1lf + %.1lf = %.1lf", firstNumber, secondNumber, firstNumber + secondNumber);
            break;
        case '-':
            printf("%.1lf - %.1lf = %.1lf", firstNumber, secondNumber, firstNumber - secondNumber);
            break;
        case '*':
            printf("%.1lf * %.1lf = %.1lf", firstNumber, secondNumber, firstNumber * secondNumber);
            break;
        case '/':
            if (secondNumber != 0.0)
                printf("%.1lf / %.1lf = %.1lf", firstNumber, secondNumber, firstNumber / secondNumber);
            else
                printf("Error! Division by zero.");
            break;
        default:
            printf("Error! Invalid operator.");
    }

    return 0;
}

实例2:字符串反转

字符串反转是一个经典的编程练习。以下是一个使用C语言实现的示例:

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

void reverseString(char *str) {
    int len = strlen(str);
    for (int i = 0; i < len / 2; i++) {
        char temp = str[i];
        str[i] = str[len - i - 1];
        str[len - i - 1] = temp;
    }
}

int main() {
    char str[] = "Hello, World!";
    printf("Original string: %s\n", str);
    reverseString(str);
    printf("Reversed string: %s\n", str);
    return 0;
}

实例3:结构体和指针

在C语言中,结构体和指针是处理复杂数据类型的重要工具。以下是一个使用结构体和指针的示例:

#include <stdio.h>

typedef struct {
    int x;
    int y;
} Point;

void printPoint(const Point *p) {
    printf("Point coordinates: (%d, %d)\n", p->x, p->y);
}

int main() {
    Point p = {3, 4};
    printPoint(&p);
    return 0;
}

实例4:文件操作

C语言提供了强大的文件操作功能。以下是一个简单的示例,用于创建和写入文件:

#include <stdio.h>

int main() {
    FILE *file = fopen("example.txt", "w");
    if (file == NULL) {
        printf("Error opening file!\n");
        return 1;
    }

    fprintf(file, "This is a test file.\n");
    fclose(file);
    printf("File written successfully.\n");
    return 0;
}

实例5:动态内存分配

动态内存分配是C语言中的一个高级特性。以下是一个示例,演示如何使用mallocfree

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

int main() {
    int *ptr = (int *)malloc(5 * sizeof(int));
    if (ptr == NULL) {
        printf("Memory not allocated.\n");
        exit(0);
    }

    printf("Address of ptr: %d\n", (int)ptr);
    printf("Value of ptr: %d\n", *ptr);

    free(ptr);
    return 0;
}

实例6:递归函数

递归是C语言中的一个高级概念。以下是一个使用递归计算阶乘的示例:

#include <stdio.h>

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

int main() {
    int n = 5;
    printf("Factorial of %d = %d\n", n, factorial(n));
    return 0;
}

实例7:排序算法

排序算法是编程中的基本技能。以下是一个使用冒泡排序算法的示例:

#include <stdio.h>

void bubbleSort(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[] = {64, 34, 25, 12, 22, 11, 90};
    int n = sizeof(arr) / sizeof(arr[0]);
    bubbleSort(arr, n);
    printf("Sorted array: \n");
    for (int i = 0; i < n; i++)
        printf("%d ", arr[i]);
    printf("\n");
    return 0;
}

实例8:链表操作

链表是C语言中的一个重要数据结构。以下是一个创建和遍历单向链表的示例:

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

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

void insertAtEnd(struct Node **head_ref, int new_data) {
    struct Node *new_node = (struct Node *)malloc(sizeof(struct Node));
    struct Node *last = *head_ref;

    new_node->data = new_data;
    new_node->next = NULL;

    if (*head_ref == NULL) {
        *head_ref = new_node;
        return;
    }

    while (last->next != NULL)
        last = last->next;

    last->next = new_node;
    return;
}

void printList(struct Node *node) {
    while (node != NULL) {
        printf(" %d ", node->data);
        node = node->next;
    }
    printf("\n");
}

int main() {
    struct Node *head = NULL;

    insertAtEnd(&head, 1);
    insertAtEnd(&head, 4);
    insertAtEnd(&head, 3);
    insertAtEnd(&head, 2);

    printf("Created Linked list is: ");
    printList(head);

    return 0;
}

实例9:指针与数组

在C语言中,指针和数组紧密相关。以下是一个使用指针访问数组元素的示例:

#include <stdio.h>

int main() {
    int arr[] = {1, 2, 3, 4, 5};
    int *ptr = arr;

    for (int i = 0; i < 5; i++) {
        printf("Value of arr[%d] using pointer: %d\n", i, *(ptr + i));
    }

    return 0;
}

实例10:函数指针

函数指针是C语言中的一个高级特性,允许将函数作为参数传递。以下是一个使用函数指针的示例:

#include <stdio.h>

int add(int a, int b) {
    return a + b;
}

int main() {
    int (*funcPtr)(int, int) = add;
    int result = funcPtr(5, 3);
    printf("Result: %d\n", result);
    return 0;
}

实例11:结构体指针

结构体指针允许通过指针访问结构体成员。以下是一个使用结构体指针的示例:

#include <stdio.h>

typedef struct {
    int x;
    int y;
} Point;

void printPoint(const Point *p) {
    printf("Point coordinates: (%d, %d)\n", p->x, p->y);
}

int main() {
    Point p = {3, 4};
    printPoint(&p);
    return 0;
}

实例12:位操作

位操作是C语言中的一个重要特性,允许对整数中的单个位进行操作。以下是一个使用位操作的示例:

#include <stdio.h>

int main() {
    int a = 5; // 101 in binary
    int b = 3; // 011 in binary

    printf("a AND b = %d\n", (a & b)); // 001 in binary
    printf("a OR b = %d\n", (a | b)); // 111 in binary
    printf("a XOR b = %d\n", (a ^ b)); // 110 in binary
    printf("a NOT b = %d\n", ~(b)); // 10000001 in binary

    return 0;
}

实例13:宏定义

宏定义是C语言中的一个特性,允许创建可重用的代码片段。以下是一个使用宏定义的示例:

#include <stdio.h>

#define MAX(a, b) ((a) > (b) ? (a) : (b))

int main() {
    int x = 10;
    int y = 20;
    int max = MAX(x, y);
    printf("Maximum of %d and %d is %d\n", x, y, max);
    return 0;
}

实例14:指针与函数

在C语言中,指针与函数紧密相关。以下是一个使用指针作为函数参数的示例:

#include <stdio.h>

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

int main() {
    int x = 10;
    int y = 20;
    printf("Before swap: x = %d, y = %d\n", x, y);
    swap(&x, &y);
    printf("After swap: x = %d, y = %d\n", x, y);
    return 0;
}

实例15:结构体数组

结构体数组允许将多个结构体实例存储在数组中。以下是一个使用结构体数组的示例:

#include <stdio.h>

typedef struct {
    int id;
    char name[50];
} Student;

int main() {
    Student students[] = {
        {1, "Alice"},
        {2, "Bob"},
        {3, "Charlie"}
    };

    for (int i = 0; i < 3; i++) {
        printf("Student %d: %s\n", students[i].id, students[i].name);
    }

    return 0;
}

实例16:字符串处理函数

C语言提供了许多字符串处理函数,如strlenstrcpystrcmp。以下是一个使用这些函数的示例:

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

int main() {
    char str1[] = "Hello";
    char str2[] = "World";

    printf("Length of str1: %d\n", strlen(str1));
    printf("Length of str2: %d\n", strlen(str2));
    printf("Comparison of str1 and str2: %d\n", strcmp(str1, str2));
    printf("Copy of str1 to str2: %s\n", strcpy(str2, str1));

    return 0;
}

实例17:递归函数

递归函数是C语言中的一个高级概念,允许函数调用自身。以下是一个使用递归计算阶乘的示例:

#include <stdio.h>

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

int main() {
    int n = 5;
    printf("Factorial of %d = %d\n", n, factorial(n));
    return 0;
}

实例18:链表操作

链表是C语言中的一个重要数据结构,允许动态存储数据。以下是一个创建和遍历单向链表的示例:

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

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

void insertAtEnd(struct Node **head_ref, int new_data) {
    struct Node *new_node = (struct Node *)malloc(sizeof(struct Node));
    struct Node *last = *head_ref;

    new_node->data = new_data;
    new_node->next = NULL;

    if (*head_ref == NULL) {
        *head_ref = new_node;
        return;
    }

    while (last->next != NULL)
        last = last->next;

    last->next = new_node;
    return;
}

void printList(struct Node *node) {
    while (node != NULL) {
        printf(" %d ", node->data);
        node = node->next;
    }
    printf("\n");
}

int main() {
    struct Node *head = NULL;

    insertAtEnd(&head, 1);
    insertAtEnd(&head, 4);
    insertAtEnd(&head, 3);
    insertAtEnd(&head, 2);

    printf("Created Linked list is: ");
    printList(head);

    return 0;
}

实例19:指针与数组

在C语言中,指针和数组紧密相关。以下是一个使用指针访问数组元素的示例:

#include <stdio.h>

int main() {
    int arr[] = {1, 2, 3, 4, 5};
    int *ptr = arr;

    for (int i = 0; i < 5; i++) {
        printf("Value of arr[%d] using pointer: %d\n", i, *(ptr + i));
    }

    return 0;
}

实例20:函数指针

函数指针是C语言中的一个高级特性,允许将函数作为参数传递。以下是一个使用函数指针的示例:

#include <stdio.h>

int add(int a, int b) {
    return a + b;
}

int main() {
    int (*funcPtr)(int, int) = add;
    int result = funcPtr(5, 3);
    printf("Result: %d\n", result);
    return 0;
}

实例21:结构体指针

结构体指针允许通过指针访问结构体成员。以下是一个使用结构体指针的示例:

#include <stdio.h>

typedef struct {
    int x;
    int y;
} Point;

void printPoint(const Point *p) {
    printf("Point coordinates: (%d, %d)\n", p->x, p->y);
}

int main() {
    Point p = {3, 4};
    printPoint(&p);
    return 0;
}

实例22:位操作

位操作是C语言中的一个重要特性,允许对整数中的单个位进行操作。以下是一个使用位操作的示例:

#include <stdio.h>

int main() {
    int a = 5; // 101 in binary
    int b = 3; // 011 in binary

    printf("a AND b = %d\n", (a & b)); // 001 in binary
    printf("a OR b = %d\n", (a | b)); // 111 in binary
    printf("a XOR b = %d\n", (a ^ b)); // 110 in binary
    printf("a NOT b = %d\n", ~(b)); // 10000001 in binary

    return 0;
}

实例23:宏定义

宏定义是C语言中的一个特性,允许创建可重用的代码片段。以下是一个使用宏定义的示例:

#include <stdio.h>

#define MAX(a, b) ((a) > (b) ? (a) : (b))

int main() {
    int x = 10;
    int y = 20;
    int max = MAX(x, y);
    printf("Maximum of %d and %d is %d\n", x, y, max);
    return 0;
}

实例24:指针与函数

在C语言中,指针与函数紧密相关。以下是一个使用指针作为函数参数的示例:

#include <stdio.h>

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

int main() {
    int x = 10;
    int y = 20;
    printf("Before swap: x = %d, y = %d\n", x, y);
    swap(&x, &y);
    printf("After swap: x = %d, y = %d\n", x, y);
    return 0;
}

实例25:结构体数组

结构体数组允许将多个结构体实例存储在数组中。以下是一个使用结构体数组的示例:

#include <stdio.h>

typedef struct {
    int id;
    char name[50];
} Student;

int main() {
    Student students[] = {
        {1, "Alice"},
        {2, "Bob"},
        {3, "Charlie"}
    };

    for (int i = 0; i < 3; i++) {
        printf("Student %d: %s\n", students[i].id, students[i].name);
    }

    return 0;
}

实例26:字符串处理函数

C语言提供了许多字符串处理函数,如strlenstrcpystrcmp。以下是一个使用这些函数的示例:

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

int main() {
    char str1[] = "Hello";
    char str2[] = "World";

    printf("Length of str1: %d\n", strlen(str1));
    printf("Length of str2: %d\n", strlen(str2));
    printf("Comparison of str1 and str2: %d\n", strcmp(str1, str2));
    printf("Copy of str1 to str2: %s\n", strcpy(str2, str1));

    return 0;
}

实例27:递归函数

递归函数是C语言中的一个高级概念,允许函数调用自身。以下是一个使用递归计算阶乘的示例:

#include <stdio.h>

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

int main() {
    int n = 5;
    printf("Factorial of %d = %d\n", n, factorial(n));
    return 0;
}