| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 354 人关注过本帖
标题:指针字符串的比较
只看楼主 加入收藏
qq1274371820
Rank: 1
等 级:新手上路
帖 子:149
专家分:0
注 册:2013-11-24
结帖率:75.86%
收藏
已结贴  问题点数:10 回复次数:3 
指针字符串的比较

                       输入10个字符串,按英文字典排序输出。要求用指针数组实现

                     我很疑惑,这个也要加上 *p='\0';吗?
                   还有,这个程序错在哪儿了呢?


 #include"stdio.h"
void rank(char *p)
{
    int i;
    char x;
    for(i=1;*(p+i)!='\0';i++)
    {
        if(*p>*(p+i))
        {
            x=*p;
            *p=*(p+i);
            *(p+i)=x;
        }
    }
    printf("%s\n",*p);
}
int main()
{
    char str[100];
    gets(str);
    rank(str);
    return 0;
}
搜索更多相关主题的帖子: 英文字典 include return 字符串 
2013-12-14 17:38
wangshui125
Rank: 2
等 级:论坛游民
帖 子:28
专家分:36
注 册:2011-10-25
收藏
得分:5 
#include"stdio.h"
void rank(char *p)
{
    int i;
    char x;
    for(i=1;*(p+i)!='\0';i++)
    {
        if(*p>*(p+i))
        {
            x=*p;
            *p=*(p+i);
            *(p+i)=x;
        }
    }
//这段好像只是把最小的放在了第一位,后面的没排序
    printf("%s\n",*p);//这个好像也有问题吧?
}
int main()
{
    char str[100];
    gets(str);
    rank(str);
    return 0;
}
2013-12-14 18:18
li_local
Rank: 2
等 级:论坛游民
帖 子:35
专家分:59
注 册:2013-11-21
收藏
得分:5 
排序那里写错了。还有输出那里写错了。
/*最经典的冒泡排序算法*/
#include <string.h>
#include"stdio.h"
void rank(char *p)
{
    int i,j;
    char tmp_str;
    printf("原始字符串是%s\n",p);
    for(i=0;*(p+i)!='\0';i++)
    {   
        for(j=i+1;*(p+j)!=0;j++)
        {
            if(*(p+i) > *(p+j))
            {
                tmp_str = *(p+i);
                *(p+i) = *(p+j);
                *(p+j)=tmp_str;
            }
        }

    }
    printf("输出的字符串是:");
    printf("%s\n",p);
}
int main()
{
    char str[100];
    printf("输入字符串(长度小于100):\n");
    gets(str);
    if(strlen(str) > 99)
    {
        printf("输入字符串长度过多,重新输入");
        return 0;
    }
    rank(str);
    return 0;
}
2013-12-14 19:58
qq1274371820
Rank: 1
等 级:新手上路
帖 子:149
专家分:0
注 册:2013-11-24
收藏
得分:0 
回复 3楼 li_local


            那这个呢?
             我想问这个有没有不好的地方

void chooserank(char *p)
{
    int i,j,len,k;
    char x;
    len=strlen(p);
    for(i=0;*(p+i)!='\0';i++)
    {
        k=i;
        for(j=i+1;j<len;j++)
        {
            if(*(p+j)<*(p+k))
            {
                k=j;
            }
            if(k!=i)
            {
                x=*(p+i);
                *(p+i)=*(p+k);
                *(p+k)=x;
            }
        }
    }
    printf("%s\n",p);
}

自定义人生。。。
2013-12-15 12:30
快速回复:指针字符串的比较
数据加载中...
 
   



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

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