| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 764 人关注过本帖
标题:【求助】冒泡排序-指针
取消只看楼主 加入收藏
zh1354453922
Rank: 1
等 级:新手上路
帖 子:19
专家分:1
注 册:2010-11-11
结帖率:50%
收藏
已结贴  问题点数:20 回复次数:1 
【求助】冒泡排序-指针
我想用函数调用的方式进行冒泡排序,用指针变量做实参和形参...但是错了很多...求高手帮帮
程序代码:
/* 2.使用指针作形参,指针为实参*/
#include<stdio.h>
int main()
{
    void sort(int *p,int n);
    int i,a[15],n,*p;
    p=a;
    printf("Please input the array's number:");
    scanf("%d",&n);
    printf("Please inpur the array's data:");
    for(i=0;i<n;i++)
        scanf("%d",p++);
    p=a;
    printf("The origin array is:");
    for(i=0;i<n;i++)
        printf("%5d",*p++);
    printf("\n");
    p=a;
    sort(p,n);
    p=a;
    for(i=0;i<n;i++)
        printf("%5d",*p++);
    printf("\n");
    return 0;
}
void sort(int *p,int n)
{
    int i,j,*q,*t,temp;
    for(i=0;i<n-1;i++)
        for(j=0;i+j<n-1;j++,p++){
            q=p+1;
            if(*p>*q){
                temp=*p;
                *p=*q;
                *q=temp;
                t=q;
            }
            else t=p;
        }
       
}

搜索更多相关主题的帖子: 指针 冒泡 
2010-11-20 21:46
zh1354453922
Rank: 1
等 级:新手上路
帖 子:19
专家分:1
注 册:2010-11-11
收藏
得分:0 
程序代码:
void sort(int *p,int n)
{    
    int i,j,*q,*t,temp;//q指向p的下一个地址,使用其做比较
    for(i=0;i<n-1;i++,p=p-(n-i))//p=p-(n-i)是为了每次循环结束后让p指向数组的首地址
        for(j=0;i+j<n-1;j++,p++){
            q=p+1;
            if(*p>*q){        //相邻间的数据进行比较,使大的数沉下来
                temp=*p;
                *p=*q;
                *q=temp;
            }
        }
       
}
自己改好了
2010-11-21 09:58
快速回复:【求助】冒泡排序-指针
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.048756 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved