| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1037 人关注过本帖
标题:来来来,看看哪里错了
只看楼主 加入收藏
see235959850
Rank: 2
等 级:论坛游民
帖 子:380
专家分:29
注 册:2016-12-21
结帖率:100%
收藏
 问题点数:0 回复次数:5 
来来来,看看哪里错了
程序代码:
#include<stdio.h>
#include<string.h>
void sort(char *a[], int n)
{
    int i, j, m = 0;
    char **p, t;
    p = a + 0;
    for (i = 0; i < n - 1; i++)
    {
        m = i;
        for (j = i + 1; j < n; j++)
            if (strcmp(p[m], p[j]) > 0)
                m = j;
        if (m != i)
        {
            t = *p[i];
            *p[i] = *p[m];
            *p[m] = t;
        }
    }
}

void print_string(char *a[], int n)
{
    int i;
    char **p;
    p = a;
    for (i = 0; i < n; i++, p++)
        printf("%s\n", *p);
}

int main()
{
    void sort(char *a[], int n);
    void print_string(char *a[], int n);
    char *a[3] = { "Holle","Welcome","Cart" };
    sort(a, 3);
    print_string(a, 3);
    return 0;
}

装了vs2017 rc后的第一弹
2017-01-16 19:24
see235959850
Rank: 2
等 级:论坛游民
帖 子:380
专家分:29
注 册:2016-12-21
收藏
得分:0 
顺便问一下,我不想在主函数中输入字符串,自己写一个函数怎么用这个字符串数组指针
2017-01-16 19:34
xzlxzlxzl
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖北
等 级:贵宾
威 望:125
帖 子:1091
专家分:5825
注 册:2014-5-3
收藏
得分:0 
指针数组指向的字符串常量,不能更改,所以排序时无法交换,排序函数修改如下即可:
void sort(char *a[], int n)
{
    int i, j, m = 0;
    char **p, *t;
    p = a + 0;
    for (i = 0; i < n - 1; i++)
    {
        m = i;
        for (j = i + 1; j < n; j++)
            if (strcmp(p[m], p[j]) > 0)
                m = j;
        if (m != i)
        {
            t = p[i];
            p[i] = p[m];
            p[m] = t;
        }
    }
}
2017-01-16 19:36
groveer
Rank: 3Rank: 3
来 自:世界的一角
等 级:论坛游侠
威 望:1
帖 子:77
专家分:182
注 册:2013-11-18
收藏
得分:0 
程序代码:
#include<stdio.h>
#include<string.h>

void sort(char *a[], int n)
{
    int i, j, m = 0;
    char **p, *t;
    p = a + 0;//a+0是什么意思?
    for (i = 0; i < n - 1; i++)
    {
        m = i;
        for (j = i + 1; j < n; j++)
            if (strcmp(p[m], p[j]) > 0)
                m = j;
        if (m != i)
        {
            t = p[i];//楼主的循环不是为了字符排序 应是字符串排序吧?
            p[i] = p[m];
            p[m] = t;
        }
    }
}

void print_string(char *a[], int n)
{
    int i;
    char **p;
    p = a;
    for (i = 0; i < n; i++, p++)
        printf("%s\n", *p);
}

int main()
{
    void sort(char *a[], int n);
    void print_string(char *a[], int n);
    char *a[3] = { "Holle","Welcome","Cart" };
    sort(a, 3);
    print_string(a, 3);
    return 0;
}

付出不亚于任何人的努力~
2017-01-16 19:43
炎天
Rank: 13Rank: 13Rank: 13Rank: 13
来 自:桃花岛
等 级:贵宾
威 望:29
帖 子:1218
专家分:4986
注 册:2016-9-15
收藏
得分:0 
回复 2楼 see235959850
程序代码:
#include<stdio.h>
#include<string.h>
#define N 3
char b[N][20];

void sort(char *a[], int n)
{
    int i, j, m = 0;
    char **p, *t;
    p = a + 0;
    for (i = 0; i < n - 1; i++)
    {
        m = i;
        for (j = i + 1; j < n; j++)
            if (strcmp(p[m], p[j]) > 0)
                m = j;
        if (m != i)
        {
          t = p[i];
          p[i] = p[m];
          p[m] = t;
        }
    }
}

void print_string(char *a[], int n)
{
    int i;
    char **p;
    p = a;
    for (i = 0; i < n; i++)
        printf("%s\n", p[i]);
}

void func(void)
{
    int i = 0;
    for(i = 0; i < N; i++)
    {
        gets(b[i]);
    }
}    

int main()
{
    int i = 0;
    void sort(char *a[], int n);
    void print_string(char *a[], int n);
    void func();
    //char b[3][20] = { "Holle","Welcome","Cart" };
    char *a[3];
    for(i = 0; i < N; i++)
    {
        a[i] = b[i];
    }
    func();
    sort(a, N);
    print_string(a, N);
    return 0;
}


[此贴子已经被作者于2017-1-16 19:58编辑过]


早知做人那么辛苦!  当初不应该下凡
2017-01-16 19:57
qdcs
Rank: 6Rank: 6
等 级:侠之大者
威 望:5
帖 子:171
专家分:458
注 册:2016-12-22
收藏
得分:0 
程序代码:
#include<stdio.h>
#include<string.h>
void sort(char *a[], int n)
{
    int i, j, m = 0;
    char **p, *t;                 //这里t应该是指针
    p = a + 0;
    for (i = 0; i < n - 1; i++)
    {
        m = i;
        for (j = i + 1; j < n; j++)
            if (strcmp(p[m], p[j]) > 0)
                m = j;
        if (m != i)
        {
            t = p[i];              //这里取指针交换
            p[i] = p[m];           //同上
            p[m] = t;
        }
    }
}

//



[此贴子已经被作者于2017-1-16 22:53编辑过]


我是硬件工程师
2017-01-16 22:44
快速回复:来来来,看看哪里错了
数据加载中...
 
   



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

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