鱼C论坛

 找回密码
 立即注册
查看: 2255|回复: 3

C语言关于用指针实现冒泡排序的功能(也许这个问题你们已经处理过了,但我还不知道)

[复制链接]
发表于 2015-12-10 15:38:51 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
现在正在看小甲鱼老师的《0基础入门学习C语言》指针部分,当讲到指针和数组的关系的时候,谭浩强的书《C程序设计》里给了一个用指针实现冒泡排序功能的算法,我本人觉得太繁琐,所以就想像之前的数组实现冒泡排序的方法写了一下,但发现实现不了功能。源码如下:
#include<stdio.h>

void sort(int *x,int n);
void main()
{
        int a[10];
        int *p;
       
        for(p=a;p<a+10;p++)
        {
                scanf("%d",p);
        }
        p=a;
        sort(p,10);
        for(p=a;p<a+10;p++)
        {
                printf("%d  ",*p);
        }
        printf("\n");
}

void sort(int *x,int n)
{
        int temp,*i,*j;
        for(i=x;i<x+n;i++)
        {
                for(j=i;j<x+n;j++)
                {
                        if((*j)>(*(j+1)))
                        {
                                temp=*j;
                                *j=*(j+1);
                                *(j+1)=temp;
                        }
                }
        }
}


小白刚玩论坛,还希望各位大神多多指教!也许这个问题你们已经处理过了,但我还不知道。

QQ图片20151210153444.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2015-12-10 18:59:41 | 显示全部楼层
#include<stdio.h>

void sort(int *x, int n);
void main()
{
        int a[10];
        int *p;

        for (p = a; p < a + 10; p++)
        {
                scanf_s("%d", p);
        }
        p = a;
        sort(p, 10);
        for (p = a; p < a + 10; p++)
        {
                printf("%d  ", *p);
        }
        printf("\n");
}

void sort(int *x, int n)
{
        int temp, *i, *j;
        for (i = x; i < x + n; i++)
        {
                for (j = x; j<x + n-(i-x+1); j++)     //唯一修改了这里,你的冒泡排序是错的
                {
                        if ((*j)>(*(j + 1)))
                        {
                                temp = *j;
                                *j = *(j + 1);
                                *(j + 1) = temp;
                        }
                }
        }
}
1.JPG
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2015-12-11 01:37:02 From FishC Mobile | 显示全部楼层
什么问题
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2015-12-11 07:51:16 | 显示全部楼层

是的是的,每次排序完要刷新一下P的指向,话说谭的书为什么写那么复杂
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-26 14:51

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表