实例1:打印Hello World
在C语言编程中,第一个实例通常是打印“Hello World”到屏幕上。这是一个简单的例子,用于展示C语言的基本语法。
#include <stdio.h>
int main() {
printf("Hello World\n");
return 0;
}
这个程序包含了stdio.h头文件,它提供了printf函数,用于输出文本到屏幕。main函数是程序的入口点,而return 0;表示程序成功执行。
实例2:变量和赋值
变量是存储数据的容器。在C语言中,变量必须先声明后使用。
#include <stdio.h>
int main() {
int age = 25;
printf("My age is %d\n", age);
return 0;
}
在这个例子中,我们声明了一个名为age的整型变量,并将其赋值为25。然后,我们使用printf函数打印这个变量的值。
实例3:数据类型
C语言提供了多种数据类型,如整型、浮点型、字符型等。
#include <stdio.h>
int main() {
int i = 10;
float f = 3.14f;
char c = 'A';
printf("Integer: %d\n", i);
printf("Float: %f\n", f);
printf("Char: %c\n", c);
return 0;
}
在这个例子中,我们声明了三种不同类型的变量,并分别赋值。
实例4:运算符
C语言提供了各种运算符,如算术运算符、关系运算符、逻辑运算符等。
#include <stdio.h>
int main() {
int a = 5, b = 3;
printf("Sum: %d\n", a + b);
printf("Difference: %d\n", a - b);
printf("Product: %d\n", a * b);
printf("Quotient: %d\n", a / b);
printf("Modulus: %d\n", a % b);
return 0;
}
在这个例子中,我们使用算术运算符来计算两个整数的和、差、积、商和余数。
实例5:条件语句
条件语句用于根据条件执行不同的代码块。
#include <stdio.h>
int main() {
int num = 10;
if (num > 0) {
printf("The number is positive\n");
} else if (num < 0) {
printf("The number is negative\n");
} else {
printf("The number is zero\n");
}
return 0;
}
在这个例子中,我们使用if语句来判断一个整数的正负。
实例6:循环语句
循环语句用于重复执行一段代码。
#include <stdio.h>
int main() {
int i;
for (i = 1; i <= 5; i++) {
printf("Iteration %d\n", i);
}
return 0;
}
在这个例子中,我们使用for循环来打印从1到5的数字。
实例7:函数
函数是代码块,用于执行特定的任务。
#include <stdio.h>
void greet() {
printf("Hello, World!\n");
}
int main() {
greet();
return 0;
}
在这个例子中,我们定义了一个名为greet的函数,用于打印“Hello, World!”。
实例8:指针
指针是存储变量地址的变量。
#include <stdio.h>
int main() {
int a = 10;
int *ptr = &a;
printf("Value of a: %d\n", a);
printf("Address of a: %p\n", (void *)&a);
printf("Value of ptr: %p\n", (void *)ptr);
printf("Value pointed by ptr: %d\n", *ptr);
return 0;
}
在这个例子中,我们声明了一个整型变量a和一个指向整型的指针ptr。然后,我们打印了a的值、地址、指针的值以及指针指向的值。
实例9:结构体
结构体是一种用户自定义的数据类型,可以包含不同类型的数据。
#include <stdio.h>
typedef struct {
int id;
char name[50];
} Student;
int main() {
Student s1;
s1.id = 1;
strcpy(s1.name, "John Doe");
printf("ID: %d\n", s1.id);
printf("Name: %s\n", s1.name);
return 0;
}
在这个例子中,我们定义了一个名为Student的结构体,它包含了一个整型变量id和一个字符数组name。然后,我们创建了一个Student类型的变量s1,并给它赋值。
实例10:数组
数组是存储相同类型数据的集合。
#include <stdio.h>
int main() {
int arr[5] = {1, 2, 3, 4, 5};
for (int i = 0; i < 5; i++) {
printf("arr[%d] = %d\n", i, arr[i]);
}
return 0;
}
在这个例子中,我们声明了一个整型数组arr,并初始化了它的元素。然后,我们使用for循环遍历数组并打印每个元素的值。
实例11:字符串处理
C语言提供了多种字符串处理函数,如strlen、strcpy、strcmp等。
#include <stdio.h>
#include <string.h>
int main() {
char str1[50] = "Hello";
char str2[50] = "World";
printf("Length of str1: %d\n", strlen(str1));
strcpy(str1, str2);
printf("str1 after copy: %s\n", str1);
printf("Result of strcmp: %d\n", strcmp(str1, str2));
return 0;
}
在这个例子中,我们使用strlen函数来获取字符串的长度,strcpy函数来复制字符串,以及strcmp函数来比较两个字符串。
实例12:文件操作
C语言提供了文件操作函数,如fopen、fclose、fread、fwrite等。
#include <stdio.h>
int main() {
FILE *file = fopen("example.txt", "w");
if (file == NULL) {
printf("Error opening file\n");
return 1;
}
fprintf(file, "Hello, World!\n");
fclose(file);
return 0;
}
在这个例子中,我们使用fopen函数以写入模式打开一个名为example.txt的文件。然后,我们使用fprintf函数将文本写入文件,并使用fclose函数关闭文件。
实例13:动态内存分配
C语言提供了动态内存分配函数,如malloc、calloc、realloc、free等。
#include <stdio.h>
#include <stdlib.h>
int main() {
int *arr = (int *)malloc(5 * sizeof(int));
if (arr == NULL) {
printf("Error allocating memory\n");
return 1;
}
for (int i = 0; i < 5; i++) {
arr[i] = i;
}
for (int i = 0; i < 5; i++) {
printf("arr[%d] = %d\n", i, arr[i]);
}
free(arr);
return 0;
}
在这个例子中,我们使用malloc函数动态分配了一个整型数组arr,并使用free函数释放了内存。
实例14:结构体数组
结构体数组是存储相同结构体类型的集合。
#include <stdio.h>
typedef struct {
int id;
char name[50];
} Student;
int main() {
Student students[3] = {
{1, "John Doe"},
{2, "Jane Smith"},
{3, "Alice Johnson"}
};
for (int i = 0; i < 3; i++) {
printf("ID: %d, Name: %s\n", students[i].id, students[i].name);
}
return 0;
}
在这个例子中,我们声明了一个Student类型的结构体数组students,并初始化了它的元素。
实例15:指针数组
指针数组是存储指针的集合。
#include <stdio.h>
int main() {
int a = 10, b = 20;
int *ptrs[2];
ptrs[0] = &a;
ptrs[1] = &b;
for (int i = 0; i < 2; i++) {
printf("Value: %d\n", *ptrs[i]);
}
return 0;
}
在这个例子中,我们声明了一个整型指针数组ptrs,并初始化了它的元素。
实例16:函数指针
函数指针是指向函数的指针。
#include <stdio.h>
void printHello() {
printf("Hello\n");
}
int main() {
void (*funcPtr)() = printHello;
funcPtr();
return 0;
}
在这个例子中,我们声明了一个函数指针funcPtr,它指向printHello函数,并调用它。
实例17:递归函数
递归函数是一种自己调用自己的函数。
#include <stdio.h>
int factorial(int n) {
if (n <= 1) {
return 1;
}
return n * factorial(n - 1);
}
int main() {
int num = 5;
printf("Factorial of %d is %d\n", num, factorial(num));
return 0;
}
在这个例子中,我们定义了一个递归函数factorial来计算一个整数的阶乘。
实例18:结构体指针
结构体指针是指向结构体的指针。
#include <stdio.h>
typedef struct {
int id;
char name[50];
} Student;
int main() {
Student s1 = {1, "John Doe"};
Student *ptr = &s1;
printf("ID: %d, Name: %s\n", ptr->id, ptr->name);
return 0;
}
在这个例子中,我们声明了一个Student类型的结构体指针ptr,并指向了Student类型的变量s1。
实例19:函数指针数组
函数指针数组是存储函数指针的集合。
#include <stdio.h>
void printHello() {
printf("Hello\n");
}
void printWorld() {
printf("World\n");
}
int main() {
void (*funcPtrs[2])() = {printHello, printWorld};
funcPtrs[0]();
funcPtrs[1]();
return 0;
}
在这个例子中,我们声明了一个函数指针数组funcPtrs,并初始化了它的元素。
实例20:链表
链表是一种动态数据结构,由一系列节点组成,每个节点包含数据和指向下一个节点的指针。
#include <stdio.h>
#include <stdlib.h>
typedef struct Node {
int data;
struct Node *next;
} Node;
Node* createNode(int data) {
Node *newNode = (Node *)malloc(sizeof(Node));
newNode->data = data;
newNode->next = NULL;
return newNode;
}
void insertNode(Node **head, int data) {
Node *newNode = createNode(data);
if (*head == NULL) {
*head = newNode;
} else {
Node *current = *head;
while (current->next != NULL) {
current = current->next;
}
current->next = newNode;
}
}
void printList(Node *head) {
Node *current = head;
while (current != NULL) {
printf("%d ", current->data);
current = current->next;
}
printf("\n");
}
void freeList(Node *head) {
Node *current = head;
while (current != NULL) {
Node *temp = current;
current = current->next;
free(temp);
}
}
int main() {
Node *head = NULL;
insertNode(&head, 1);
insertNode(&head, 2);
insertNode(&head, 3);
printList(head);
freeList(head);
return 0;
}
在这个例子中,我们定义了一个链表,并实现了创建节点、插入节点、打印链表和释放链表的功能。
实例21:栈
栈是一种后进先出(LIFO)的数据结构。
#include <stdio.h>
#include <stdlib.h>
#define MAX_SIZE 10
typedef struct {
int items[MAX_SIZE];
int top;
} Stack;
void initializeStack(Stack *s) {
s->top = -1;
}
int isEmpty(Stack *s) {
return s->top == -1;
}
int isFull(Stack *s) {
return s->top == MAX_SIZE - 1;
}
void push(Stack *s, int item) {
if (isFull(s)) {
printf("Stack is full\n");
return;
}
s->items[++s->top] = item;
}
int pop(Stack *s) {
if (isEmpty(s)) {
printf("Stack is empty\n");
return -1;
}
return s->items[s->top--];
}
int main() {
Stack s;
initializeStack(&s);
push(&s, 1);
push(&s, 2);
push(&s, 3);
printf("Popped item: %d\n", pop(&s));
printf("Popped item: %d\n", pop(&s));
printf("Popped item: %d\n", pop(&s));
return 0;
}
在这个例子中,我们定义了一个栈,并实现了初始化、判断是否为空、判断是否已满、入栈和出栈的功能。
实例22:队列
队列是一种先进先出(FIFO)的数据结构。
#include <stdio.h>
#include <stdlib.h>
#define MAX_SIZE 10
typedef struct {
int items[MAX_SIZE];
int front;
int rear;
} Queue;
void initializeQueue(Queue *q) {
q->front = q->rear = -1;
}
int isEmpty(Queue *q) {
return q->front == -1;
}
int isFull(Queue *q) {
return (q->rear + 1) % MAX_SIZE == q->front;
}
void enqueue(Queue *q, int item) {
if (isFull(q)) {
printf("Queue is full\n");
return;
}
if (isEmpty(q)) {
q->front = q->rear = 0;
} else {
q->rear = (q->rear + 1) % MAX_SIZE;
}
q->items[q->rear] = item;
}
int dequeue(Queue *q) {
if (isEmpty(q)) {
printf("Queue is empty\n");
return -1;
}
int item = q->items[q->front];
if (q->front == q->rear) {
q->front = q->rear = -1;
} else {
q->front = (q->front + 1) % MAX_SIZE;
}
return item;
}
int main() {
Queue q;
initializeQueue(&q);
enqueue(&q, 1);
enqueue(&q, 2);
enqueue(&q, 3);
printf("Dequeued item: %d\n", dequeue(&q));
printf("Dequeued item: %d\n", dequeue(&q));
printf("Dequeued item: %d\n", dequeue(&q));
return 0;
}
在这个例子中,我们定义了一个队列,并实现了初始化、判断是否为空、判断是否已满、入队和出队的功能。
实例23:二叉树
二叉树是一种树形数据结构,每个节点最多有两个子节点。
#include <stdio.h>
#include <stdlib.h>
typedef struct Node {
int data;
struct Node *left;
struct Node *right;
} Node;
Node* createNode(int data) {
Node *newNode = (Node *)malloc(sizeof(Node));
newNode->data = data;
newNode->left = NULL;
newNode->right = NULL;
return newNode;
}
void insertNode(Node **root, int data) {
if (*root == NULL) {
*root = createNode(data);
} else {
Node *current = *root;
while (current != NULL) {
if (data < current->data) {
if (current->left == NULL) {
current->left = createNode(data);
break;
}
current = current->left;
} else {
if (current->right == NULL) {
current->right = createNode(data);
break;
}
current = current->right;
}
}
}
}
void printInOrder(Node *root) {
if (root != NULL) {
printInOrder(root->left);
printf("%d ", root->data);
printInOrder(root->right);
}
}
void freeTree(Node *root) {
if (root != NULL) {
freeTree(root->left);
freeTree(root->right);
free(root);
}
}
int main() {
Node *root = NULL;
insertNode(&root, 5);
insertNode(&root, 3);
insertNode(&root, 7);
insertNode(&root, 2);
insertNode(&root, 4);
insertNode(&root, 6);
insertNode(&root, 8);
printf("In-order traversal: ");
printInOrder(root);
printf("\n");
freeTree(root);
return 0;
}
在这个例子中,我们定义了一个二叉树,并实现了创建节点、插入节点、中序遍历和释放树的功能。
实例24:排序算法
排序算法用于将一组数据按特定顺序排列。
”`c
#include
void swap(int *a, int *b) {
int temp = *
