标题:运用指针数组进行短字符串排序,但是就是无法实现!
取消只看楼主
S140131022
Rank: 2
来 自:重庆邮电大学
等 级:论坛游民
帖 子:205
专家分:35
注 册:2014-10-9
结帖率:90.24%
已结贴  问题点数:20 回复次数:2 
运用指针数组进行短字符串排序,但是就是无法实现!
//字符串比较选择排序为何没有实现

#include<stdio.h>
#include<string.h>

int main()
{
    void print(char (*x)[10]);
    void convert(char *p[10]);
    int i;
    char x[10][10];

    char *p[10];
    for(i=0;i<10;i++)
        p[i]=&x[i][0];
    for(i=0;i<10;i++)
        gets(p[i]);
    puts("The data is:");
    print(x);
    convert(p);
    puts("The right folling is of the array is:");
    print(x);
    return 0;
}

void print(char (*p)[10])
{
    int i;
    for(i=0;i<10;i++)
    {
        puts(*(p+i));
    }
    putchar('\n');
}

void convert(char *p[10])
{
    int i,j,k;
    char *q;
    for(i=0;i<9;i++)
    {
        k=i;
        for(j=i+1;j<10;j++)                   //注意:此处j=i+1而非j=1
        {
            if(strcmp(p[j],p[k])<0)
                k=j;
        }
        if(k!=i)
        {
            q=p[i];
            p[i]=p[k];
            p[k]=q;
        }
    }
}

//sO 可以正常输出字符串 就是没法排序,不晓得问题出在了什么地方!!!~~~~(>_<)~~~~
搜索更多相关主题的帖子: convert include return 字符串 
2015-04-09 20:33
S140131022
Rank: 2
来 自:重庆邮电大学
等 级:论坛游民
帖 子:205
专家分:35
注 册:2014-10-9
得分:0 
应该是convert函数的问题!  但是我检查感觉没有问题

既然还有不甘心
就还没到放弃的时候~
2015-04-09 20:34
S140131022
Rank: 2
来 自:重庆邮电大学
等 级:论坛游民
帖 子:205
专家分:35
注 册:2014-10-9
得分:0 
//我知道所犯的错误,程序修改正确如下! 谢谢大家的帮助~

#include<stdio.h>
#include<string.h>

int main()
{
    void print(char *x[]);
    void convert(char *p[10]);
    int i;
    char x[10][10];

    char *p[10];
    for(i=0;i<10;i++)
        p[i]=&x[i][0];
    for(i=0;i<10;i++)
        gets(p[i]);
    puts("The data is:");
    print(p);
    convert(p);
    puts("The right folling is of the array is:");
    print(p);
    return 0;
}

void print(char *p[])
{
    int i;
    for(i=0;i<10;i++)
    {
        puts(*(p+i));
    }
    putchar('\n');
}

void convert(char *p[10])                     //经过convert函数交换之后相当于指针数组*P[10]的指向发生了排序,而未对X中的数据排序
                                              //而输出又用的print(x)相当于输出数据,所以才会功亏一窥啊!
{
    int i,j,k;
    char *q;
    for(i=0;i<9;i++)
    {
        k=i;
        for(j=i+1;j<10;j++)                   //注意:此处j=i+1而非j=1
        {
            if(strcmp(p[j],p[k])<0)
                k=j;
        }
        if(k!=i)                              
        {
            q=p[i];
            p[i]=p[k];                    
            p[k]=q;      
        }
    }
}

既然还有不甘心
就还没到放弃的时候~
2015-04-10 09:19



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-443771-1-1.html




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

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