案例一:计算阶乘
在C语言中,计算阶乘是一个经典的入门级编程问题。阶乘是指一个正整数n的阶乘,记作n!,表示从1乘到n的乘积。以下是一个计算阶乘的C语言程序示例:
#include <stdio.h>
// 函数声明
unsigned long long factorial(int n);
int main() {
int number;
printf("Enter a positive integer: ");
scanf("%d", &number);
if (number < 0) {
printf("Factorial of a negative number doesn't exist.\n");
} else {
printf("Factorial of %d = %llu\n", number, factorial(number));
}
return 0;
}
// 函数定义
unsigned long long factorial(int n) {
if (n == 0)
return 1;
else
return n * factorial(n - 1);
}
在这个例子中,我们定义了一个名为factorial的递归函数来计算阶乘。主函数main负责读取用户输入并调用factorial函数。
案例二:冒泡排序
冒泡排序是一种简单的排序算法,它重复地遍历要排序的数列,每次比较两个相邻的元素,如果它们的顺序错误就把它们交换过来。以下是一个使用冒泡排序算法的C语言程序示例:
#include <stdio.h>
void bubbleSort(int arr[], int n);
int main() {
int arr[] = {64, 34, 25, 12, 22, 11, 90};
int n = sizeof(arr) / sizeof(arr[0]);
int i;
bubbleSort(arr, n);
printf("Sorted array: \n");
for (i = 0; i < n; i++)
printf("%d ", arr[i]);
printf("\n");
return 0;
}
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;
}
}
}
}
在这个例子中,我们定义了一个名为bubbleSort的函数来实现冒泡排序。主函数main创建了一个整数数组并调用bubbleSort函数对其进行排序。
案例三:结构体和指针
C语言中的结构体允许我们将不同的数据类型组合成一个单一的数据类型。指针是C语言中用于存储变量地址的数据类型。以下是一个使用结构体和指针的C语言程序示例:
#include <stdio.h>
typedef struct {
char name[50];
int age;
float salary;
} Employee;
void printEmployeeDetails(Employee *emp);
int main() {
Employee emp = {"John Doe", 30, 50000.0};
printEmployeeDetails(&emp);
return 0;
}
void printEmployeeDetails(Employee *emp) {
printf("Name: %s\n", emp->name);
printf("Age: %d\n", emp->age);
printf("Salary: %.2f\n", emp->salary);
}
在这个例子中,我们定义了一个名为Employee的结构体,其中包含姓名、年龄和薪水三个字段。我们创建了一个Employee类型的变量emp,并通过指针传递给printEmployeeDetails函数来打印其详细信息。
通过以上三个案例,我们可以看到C语言编程的实用性和灵活性。掌握这些技巧将有助于你在编程道路上更加得心应手。
