1.写冒泡排序可以排序多个字符串。
#include<stdio.h>
void bubble_sort(char *arr[],int sz)
{
int i=0;
int j = 0;
for (i = 0; i < sz - 1; i++)
{
for (j = 0; j < sz - 1 - i; j++)
{
if (strcmp(*(arr+j),*(arr+j+1))>0)
{
char *temp = *(arr + j);
*(arr + j) = *(arr + j + 1);
*(arr + j + 1) = temp;
}
}
}
}
int main()
{
int i = 0;
char* arr[] = { "bbbb","aaaa","dddd","cccc" };
int sz = sizeof(arr) / sizeof(arr[0]);
bubble_sort(arr, sz);
for (i = 0; i < sz; i++)
{
printf("%s ", *(arr+i));
}
getchar();
return 0;
}
2.使用main函数的参数,实现一个整数计算器,程序可以接受三个参数,第一个参数“ - a”选项执行加法,“ - s”选项执行减法,“ - m”选项执行乘法,“ - d”选项执行除法,后面两个参数为操作数。
例如:命令行参数输入:test.exe - a 1 2
执行1 + 2输出3
#include<stdio.h>
#include<stdlib.h>
int main(int argc,char*argv[])
{
int num1 = atoi(argv[2]);
int num2 = atoi(argv[3]);
int ret;
if (argc != 4)
{
printf("error!");
return 1;
}
if (argv[1][0] == '-')
{
switch (argv[1][1])
{
case 'a':
ret = num1 + num2;
printf("%d", ret);
break;
case 's':
ret = num1 - num2;
printf("%d", ret);
break;
case 'm':
ret = num1 * num2;
printf("%d", ret);
break;
default:
printf("scendly num error!");
break;
}
}
getchar();
return 0;
}
#include<stdio.h>
void bubble_sort(char *arr[],int sz)
{
int i=0;
int j = 0;
for (i = 0; i < sz - 1; i++)
{
for (j = 0; j < sz - 1 - i; j++)
{
if (strcmp(*(arr+j),*(arr+j+1))>0)
{
char *temp = *(arr + j);
*(arr + j) = *(arr + j + 1);
*(arr + j + 1) = temp;
}
}
}
}
int main()
{
int i = 0;
char* arr[] = { "bbbb","aaaa","dddd","cccc" };
int sz = sizeof(arr) / sizeof(arr[0]);
bubble_sort(arr, sz);
for (i = 0; i < sz; i++)
{
printf("%s ", *(arr+i));
}
getchar();
return 0;
}
2.使用main函数的参数,实现一个整数计算器,程序可以接受三个参数,第一个参数“ - a”选项执行加法,“ - s”选项执行减法,“ - m”选项执行乘法,“ - d”选项执行除法,后面两个参数为操作数。
例如:命令行参数输入:test.exe - a 1 2
执行1 + 2输出3
#include<stdio.h>
#include<stdlib.h>
int main(int argc,char*argv[])
{
int num1 = atoi(argv[2]);
int num2 = atoi(argv[3]);
int ret;
if (argc != 4)
{
printf("error!");
return 1;
}
if (argv[1][0] == '-')
{
switch (argv[1][1])
{
case 'a':
ret = num1 + num2;
printf("%d", ret);
break;
case 's':
ret = num1 - num2;
printf("%d", ret);
break;
case 'm':
ret = num1 * num2;
printf("%d", ret);
break;
default:
printf("scendly num error!");
break;
}
}
getchar();
return 0;
}
本文介绍了一个使用C语言实现的冒泡排序算法,该算法能够对字符串数组进行排序。此外,还实现了一个简单的命令行计算器,可以通过命令行参数进行基本的算术运算。
812

被折叠的 条评论
为什么被折叠?



