C语言作为一门历史悠久且广泛使用的编程语言,其简洁、高效的特点使其在嵌入式系统、操作系统、网络编程等领域有着广泛的应用。对于编程初学者来说,通过实际操作来学习C语言是掌握其核心技巧的有效途径。本文将为您呈现50个实用实例,帮助您轻松入门C语言编程。
实例1:输出“Hello, World!”
#include <stdio.h>
int main() {
printf("Hello, World!\n");
return 0;
}
这是一个简单的C语言程序,用于输出“Hello, World!”,是学习C语言的第一步。
实例2:变量与数据类型
#include <stdio.h>
int main() {
int a = 10;
float b = 3.14;
char c = 'A';
printf("a = %d, b = %f, c = %c\n", a, b, c);
return 0;
}
在这个实例中,我们学习了如何定义和使用不同数据类型的变量。
实例3:运算符
#include <stdio.h>
int main() {
int a = 5, b = 3;
printf("a + b = %d\n", a + b);
printf("a - b = %d\n", a - b);
printf("a * b = %d\n", a * b);
printf("a / b = %d\n", a / b);
printf("a % b = %d\n", a % b);
return 0;
}
本实例介绍了C语言中的基本运算符,包括加、减、乘、除和取余。
实例4:条件语句
#include <stdio.h>
int main() {
int a = 10;
if (a > 5) {
printf("a > 5\n");
} else {
printf("a <= 5\n");
}
return 0;
}
在这个实例中,我们学习了如何使用条件语句进行简单的判断。
实例5:循环语句
#include <stdio.h>
int main() {
int i;
for (i = 1; i <= 10; i++) {
printf("%d\n", i);
}
return 0;
}
本实例介绍了C语言中的for循环,用于实现重复执行的操作。
实例6:函数定义与调用
#include <stdio.h>
void printMessage() {
printf("Hello, Function!\n");
}
int main() {
printMessage();
return 0;
}
在这个实例中,我们学习了如何定义和调用函数。
实例7:数组操作
#include <stdio.h>
int main() {
int arr[5] = {1, 2, 3, 4, 5};
int i;
for (i = 0; i < 5; i++) {
printf("arr[%d] = %d\n", i, arr[i]);
}
return 0;
}
本实例介绍了如何定义、初始化和遍历数组。
实例8:指针操作
#include <stdio.h>
int main() {
int a = 10;
int *ptr = &a;
printf("a = %d, &a = %p, *ptr = %d, ptr = %p\n", a, &a, *ptr, ptr);
return 0;
}
在这个实例中,我们学习了如何使用指针访问和修改变量。
实例9:结构体
#include <stdio.h>
struct Person {
char name[50];
int age;
};
int main() {
struct Person p1;
strcpy(p1.name, "Tom");
p1.age = 20;
printf("Name: %s, Age: %d\n", p1.name, p1.age);
return 0;
}
本实例介绍了如何定义和使用结构体。
实例10:位操作
#include <stdio.h>
int main() {
int a = 5; // 0101
int b = 3; // 0011
printf("a & b = %d\n", a & b); // 0001
printf("a | b = %d\n", a | b); // 0111
printf("a ^ b = %d\n", a ^ b); // 0110
printf("a << 1 = %d\n", a << 1); // 1010
printf("a >> 1 = %d\n", a >> 1); // 0101
return 0;
}
在这个实例中,我们学习了C语言中的位操作。
实例11:文件操作
#include <stdio.h>
int main() {
FILE *fp;
char ch;
fp = fopen("example.txt", "r");
if (fp == NULL) {
printf("File cannot be opened.\n");
return 0;
}
while ((ch = fgetc(fp)) != EOF) {
printf("%c", ch);
}
fclose(fp);
return 0;
}
本实例介绍了如何使用C语言进行文件操作。
实例12:动态内存分配
#include <stdio.h>
#include <stdlib.h>
int main() {
int *ptr;
int size;
size = 10;
ptr = (int *)malloc(size * sizeof(int));
if (ptr == NULL) {
printf("Memory allocation failed.\n");
return 0;
}
for (int i = 0; i < size; i++) {
ptr[i] = i + 1;
}
for (int i = 0; i < size; i++) {
printf("%d ", ptr[i]);
}
free(ptr);
return 0;
}
在这个实例中,我们学习了如何使用malloc和free函数进行动态内存分配。
实例13:字符串操作
#include <stdio.h>
#include <string.h>
int main() {
char str1[50] = "Hello";
char str2[50] = "World";
char str3[100];
strcpy(str3, str1);
strcat(str3, str2);
printf("str3 = %s\n", str3);
printf("str1 length: %d\n", strlen(str1));
printf("str2 length: %d\n", strlen(str2));
printf("str3 length: %d\n", strlen(str3));
return 0;
}
本实例介绍了C语言中的字符串操作函数。
实例14:输入输出
#include <stdio.h>
int main() {
int a, b;
printf("Enter two numbers: ");
scanf("%d %d", &a, &b);
printf("Sum: %d\n", a + b);
return 0;
}
在这个实例中,我们学习了如何使用scanf和printf函数进行输入输出。
实例15:指针与数组
#include <stdio.h>
int main() {
int arr[5] = {1, 2, 3, 4, 5};
int *ptr = arr;
for (int i = 0; i < 5; i++) {
printf("arr[%d] = %d, *(ptr + %d) = %d\n", i, arr[i], i, *(ptr + i));
}
return 0;
}
本实例介绍了指针与数组的联系。
实例16:函数参数传递
#include <stdio.h>
void swap(int *a, int *b) {
int temp = *a;
*a = *b;
*b = temp;
}
int main() {
int x = 10, y = 20;
swap(&x, &y);
printf("x = %d, y = %d\n", x, y);
return 0;
}
在这个实例中,我们学习了如何通过指针传递参数给函数。
实例17:递归函数
#include <stdio.h>
int factorial(int n) {
if (n <= 1) {
return 1;
} else {
return n * factorial(n - 1);
}
}
int main() {
int num = 5;
printf("Factorial of %d = %d\n", num, factorial(num));
return 0;
}
本实例介绍了递归函数的概念。
实例18:结构体指针
#include <stdio.h>
struct Person {
char name[50];
int age;
};
void printPerson(struct Person *p) {
printf("Name: %s, Age: %d\n", p->name, p->age);
}
int main() {
struct Person p1;
strcpy(p1.name, "Tom");
p1.age = 20;
printPerson(&p1);
return 0;
}
在这个实例中,我们学习了如何使用结构体指针。
实例19:函数指针
#include <stdio.h>
int add(int a, int b) {
return a + b;
}
int main() {
int (*ptr)(int, int) = add;
printf("Result: %d\n", ptr(3, 4));
return 0;
}
本实例介绍了函数指针的概念。
实例20:内存分配与释放
#include <stdio.h>
#include <stdlib.h>
int main() {
int *ptr = (int *)malloc(10 * sizeof(int));
if (ptr == NULL) {
printf("Memory allocation failed.\n");
return 0;
}
for (int i = 0; i < 10; i++) {
ptr[i] = i + 1;
}
for (int i = 0; i < 10; i++) {
printf("%d ", ptr[i]);
}
free(ptr);
return 0;
}
在这个实例中,我们学习了如何使用malloc和free函数进行内存分配和释放。
实例21:字符串连接
#include <stdio.h>
#include <string.h>
int main() {
char str1[50] = "Hello";
char str2[50] = "World";
char str3[100];
strcpy(str3, str1);
strcat(str3, str2);
printf("str3 = %s\n", str3);
return 0;
}
本实例介绍了C语言中的字符串连接函数。
实例22:字符串比较
#include <stdio.h>
#include <string.h>
int main() {
char str1[50] = "Hello";
char str2[50] = "World";
char str3[50] = "Hello";
printf("strcmp(str1, str2) = %d\n", strcmp(str1, str2));
printf("strcmp(str1, str3) = %d\n", strcmp(str1, str3));
return 0;
}
在这个实例中,我们学习了如何使用strcmp函数比较字符串。
实例23:字符串查找
#include <stdio.h>
#include <string.h>
int main() {
char str1[50] = "Hello, World!";
char substr[50] = "World";
printf("strstr(str1, substr) = %ld\n", strstr(str1, substr));
return 0;
}
本实例介绍了C语言中的strstr函数,用于查找子字符串。
实例24:字符串替换
#include <stdio.h>
#include <string.h>
void strReplace(char *str, const char *old, const char *new) {
char buffer[100];
char *pos;
int len = strlen(str);
int new_len = strlen(new);
int old_len = strlen(old);
while ((pos = strstr(str, old)) != NULL) {
strncpy(buffer, str, pos - str);
buffer[pos - str] = '\0';
strcat(buffer, new);
strcpy(str, buffer);
str += new_len - old_len;
}
}
int main() {
char str[100] = "Hello, World! Hello, everyone!";
strReplace(str, "Hello", "Hi");
printf("str = %s\n", str);
return 0;
}
在这个实例中,我们学习了如何使用自定义函数进行字符串替换。
实例25:字符串分割
#include <stdio.h>
#include <string.h>
void strSplit(const char *str, const char *delim, char **tokens) {
char *pos;
int token_count = 0;
while ((pos = strstr(str, delim)) != NULL) {
tokens[token_count++] = str;
str = pos + strlen(delim);
}
tokens[token_count] = str;
}
int main() {
const char *str = "Hello, World! Welcome to C programming.";
const char *delim = " ";
char *tokens[10];
strSplit(str, delim, tokens);
for (int i = 0; i < 10; i++) {
if (tokens[i] != NULL) {
printf("%s\n", tokens[i]);
}
}
return 0;
}
本实例介绍了如何使用自定义函数进行字符串分割。
实例26:字符串加密
#include <stdio.h>
#include <string.h>
void encrypt(char *str, int shift) {
for (int i = 0; str[i] != '\0'; i++) {
if (str[i] >= 'a' && str[i] <= 'z') {
str[i] = ((str[i] - 'a' + shift) % 26) + 'a';
} else if (str[i] >= 'A' && str[i] <= 'Z') {
str[i] = ((str[i] - 'A' + shift) % 26) + 'A';
}
}
}
int main() {
char str[100] = "Hello, World!";
int shift = 3;
encrypt(str, shift);
printf("Encrypted: %s\n", str);
return 0;
}
在这个实例中,我们学习了如何使用自定义函数进行字符串加密。
实例27:字符串解密
#include <stdio.h>
#include <string.h>
void decrypt(char *str, int shift) {
for (int i = 0; str[i] != '\0'; i++) {
if (str[i] >= 'a' && str[i] <= 'z') {
str[i] = ((str[i] - 'a' - shift + 26) % 26) + 'a';
} else if (str[i] >= 'A' && str[i] <= 'Z') {
str[i] = ((str[i] - 'A' - shift + 26) % 26) + 'A';
}
}
}
int main() {
char str[100] = "Khoor, Zruog!";
int shift = 3;
decrypt(str, shift);
printf("Decrypted: %s\n", str);
return 0;
}
本实例介绍了如何使用自定义函数进行字符串解密。
实例28:冒泡排序
#include <stdio.h>
void bubbleSort(int arr[], int n) {
for (int i = 0; i < n - 1; i++) {
for (int j = 0; j < n - i - 1; j++) {
if (arr[j] > arr[j + 1]) {
int 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;
}
在这个实例中,我们学习了冒泡排序算法。
实例29:选择排序
#include <stdio.h>
void selectionSort(int arr[], int n) {
for (int i = 0; i < n - 1; i++) {
int min_idx = i;
for (int j = i + 1; j < n; j++) {
if (arr[j] < arr[min_idx]) {
min_idx = j;
}
}
int temp = arr[min_idx];
arr[min_idx] = arr[i];
arr[i] = temp;
}
}
int main() {
int arr[] = {64, 34, 25, 12, 22, 11, 90};
int n = sizeof(arr) / sizeof(arr[0]);
selectionSort(arr, n);
printf("Sorted array: \n");
for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
本实例介绍了选择排序算法。
实例30:插入排序
#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[] = {64, 34, 25, 12, 22, 11, 90};
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]);
}
printf("\n");
return 0;
}
在这个实例中,我们学习了插入排序算法。
实例31:快速排序
”`c
#include
void swap(int *a, int *b) {
int t = *a
