问题及代码:
/*
*Copyright (c) 2014,烟台大学计算机学院
*All rights reserved.
*文件名称:莉莉.cpp
*作者:李莉
*完成日期:2014年11月23日
*版本号:v1.0
*
*问题描述:对数组中的字符进行排序
*程序输入:无输入
*程序输出:按降序排列后的数组的字符
*/
#include <iostream>
using namespace std;
void bubble_sort(char arr[],int num);
void output_array (char arr[],int num);
int main()
{
char a[20]= {'s','o','r','t','b','u','b','b','l','e','s','e','l','e','c','t','o','k','o','k'};
char b[15]= {'s','o','r','t','b','u','b','b','l','e','s','e','l','e','c'};
bubble_sort(a,20); //用冒泡法按降序排序a中元素
output_array(a,20); //输出排序后的数组
bubble_sort(b,15); //用冒泡法按降序排序b中元素
output_array(b,15); //输出排序后的数组
return 0;
}
void bubble_sort(char arr[],int num)
{
int i,j,t;
for (j=0; j<num-1; j++)
{
for (i=0; i<num-j-1; i++)
{
if (arr[i]>arr[i+1])
{
t=arr[i];
arr[i]=arr[i+1];
arr[i+1]=t;
}
}
}
return;
}
void output_array(char arr[],int num)
{
int i;
for(i=num-1; i>=0; i--)
cout<<arr[i]<<" ";
cout<<endl;
return;
}
运行结果:
心得体会:字符和整形就是两个好兄弟嘛。。。。嘿嘿。。嗷呜