c语言函数二维排序 c语言函数排序一维数组
用C语言写一个函数对一个字符型二维数组排序,要求排列时根据字符多少由小到大排列
C语言版,C99标准
专注于为中小企业提供成都网站制作、成都网站建设、外贸营销网站建设服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业大邑县免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了近千家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。
==========
#includestdio.h
#includestdlib.h
#includestring.h
int icomp(const void* pa, const void* pb){
char *a=(char*)*((char**)pa), *b=(char*)*((char**)pb);
int c;
while(*a || *b){
if(c=tolower(*a)-tolower(*b)) return c;
a++; b++;
}
return (c=tolower(*a)-tolower(*b))?c:0;
}
int main(int argc,char *agv[] )
{
char *str[]={"My", "At", "so", "you", "You", "how"};//等同与str[0]...[1]等等
int i,len=sizeof(str)/sizeof(char*);
qsort(str,len,sizeof(char*),icomp);
for(i=0;ilen;i++)
printf("%d. %s\n",i, str[i]);
return 0;
}
=============
0. At
1. how
2. My
3. so
4. You
5. you
C++11版,也没能化简
==========
#includeiostream
#includealgorithm
#includecstring
using namespace std;
int main(int argc,char *agv[] )
{
char *str[]={
"My","At","so","you","You","how"
};
int i,len=sizeof(str)/sizeof(char*);
sort(str,str+len,
[](string a,string b)-int{
string la(a),lb(b);
transform(a.begin(),a.end(),la.begin(),::tolower);
transform(b.begin(),b.end(),lb.begin(),::tolower);
int r=la.compare(lb);
return r?r0:a.compare(b)0;
}
);
for(i=0;ilen;i++)
printf("%d. %s\n",i, str[i]);
return 0;
}
c语言 用子函数编辑二维数组的输入 输出 排序 逆序
//December 10,2014 By 12952010
#includestdio.h
#define row 3
#define column 3
int sort(int array[][column]){//冒泡排序
int temp,j,i;
int arr[row*column];
int k=0;
for(i=0; irow; i++)
for( j=0; jcolumn ; j++){
arr[k++]= array[i][j];
}
for(i=0;irow*column-1;i++)
for(j=0;jrow*column-i-1; j++)
if(arr[j+1]arr[j]){
temp=arr[j];
arr[j]=arr[j+1];
arr[j+1]=temp;
}
for(i=0 ,k=0; irow; i++)
for( j=0; jcolumn ; j++){
array[i][j]=arr[k++];
}
}
void show(int array[][column] ){//显示数组元素
for( int i=0 ; i row; i++ ) {
printf("\n");
for(int j=0; jcolumn; j++){
printf(" %4d ",array[i][j]);
}
}
}
void display(int array[][column]){//逆序输出
for(int i=row-1;i=0;i--){
printf("\n");
for(int j=column-1;j=0;j--)
printf(" %4d ",array[i][j]);
}
}
void setting(int array[][column]){//初始化数组
int temp=10;
for( int i=0; irow; i++ ){
for( int j=0; jcolumn; j++)
array[i][j]=temp--;
}
}
int main(){
int array[row][column];
setting(array);
printf("\n\n-------Befor sort---------\n");
show(array);
printf("\n\n-------逆序输出---------\n");
display(array);
printf("\n\n-------After sort---------\n");
sort(array);
show(array);
return 0;
}
用C语言写一个函数 于给定的二维数组 将其按下面的例子排序
参考:
#includeiostream
using namespace std;
int main()
{
int array[3][4]={{2,5,15,10},{13,24,3,6},{9,16,7,11}};
int b,temp,i,j=0,k=0,n=0,m=0;
int a[12],flag=0;
cout"排序前的数组:"endl;
for(i=0;i3;i++)
{
for(j=0;j4;j++)
coutarray[i][j]" ";
coutendl;
}
cout"排序后的数组:"endl;
for(i=0;i3;i++)//将一直数组存入一个一维数组中,在一维数组中先排好序从大到小
for(j=0;j4;j++)
{
a[k]=array[i][j];
k++;
}
for(k=0;k12;k++)
{
for(i=k+1;i12;i++)
if(a[k]a[i])
{
temp=a[k];
a[k]=a[i];
a[i]=temp;
}
}
for(j=0;j4;j++)
{
switch(flag)//当flag=0时从上到下存回原数组, flag=1 时从下到上存储
{
case 0: for(n=0;n3;n++)
{
array[n][j]=a[m];
m++;
}
flag=1;break;
case 1: for(n=2;n=0;n--)
{
array[n][j]=a[m];
m++;
}
flag=0;break;
default:break;
}
}
for(i=0;i3;i++)//输出排好序的数组
{
for(j=0;j4;j++)
coutarray[i][j]" ";
coutendl;
}
system("pause");
}
用c++编的
分享标题:c语言函数二维排序 c语言函数排序一维数组
分享URL:http://myzitong.com/article/docpjhh.html