鱼C论坛

 找回密码
 立即注册
查看: 1091|回复: 6

[已解决]兄弟们姐妹们啊,就这一个小问题,当局者迷了,大家帮看看

[复制链接]
发表于 2022-2-12 19:52:25 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 kjj2931 于 2022-2-12 19:55 编辑
void compare(char *c[],int n);
#include <stdio.h>
#include <string.h>
int main()
{
        int q = 0;
        char *c[] = {"Follow me","BASIC","Great Wall","FORTRAN","Computer design"};
        printf("这是按照要求排序后的字符串!\n\n");
        printf("%s\n\n",c[0]);//如果要输出一个字符串,使用%s,那么后面只能是地址c[0]
        printf("%c\n",*c[0]);//如果需要输出字符,那么需要加个星号,指向它输出! 
        for(q = 0;q<5;q++)
        {
                compare(c+q,q);
                printf("%s",*(c+q));
        }
        
}
void compare(char *c[],int n)
{
        int i = 0,j = 0;
        int max;
        int sum = 0;
        if(*c[n]>=65&&(*c[n]+1)>=97)
        {
                sum = strlen(c[n]);
                *c[n] = *c[n] + 32;
                for(i = 0;i<sum;i++)
                {
                        if(*c[i]==' ')
                        {
                                continue;
                        }
                        for(j = 1;j<sum;j++)
                        {
                                if(*c[j] == ' ')
                                {
                                        continue;
                                }
                                else if(*c[i]>*c[j])
                                {
                                        max = *c[i];
                                        *c[i] = *c[j];
                                        *c[j] = max;        
                                        
                                }        
                        }        
                } 
        }
        else
        {
                sum = strlen(c[n]);
                for(i = 0;i<sum;i++)
                {
                        for(j = 1;j<sum;j++)
                        {
                                if(*c[i]>*c[j])
                                {
                                        max = *c[i];
                                        *c[i] = *c[j];
                                        *c[j] = max;        
                                        
                                }        
                        }        
                } 
        }
}

出错位置一直在第13行,一编译就显示[Warning] passing argument 1 of 'compare' from incompatible pointer type    还有expected 'char **' but argument is of type 'char *'
最佳答案
2022-2-12 20:02:40
本帖最后由 jhq999 于 2022-2-12 20:04 编辑

字符串常量不允许修改
void compare(char *c[],int n);
#include <stdio.h>
#include <string.h>
int main()
{
        int q = 0;
        char *c[] = {"Follow me","BASIC","Great Wall","FORTRAN","Computer design"};/////////////////////////这里面都是字符串常量
        printf("这是按照要求排序后的字符串!\n\n");
        printf("%s\n\n",c[0]);//如果要输出一个字符串,使用%s,那么后面只能是地址c[0]
        printf("%c\n",*c[0]);//如果需要输出字符,那么需要加个星号,指向它输出! 
        for(q = 0;q<5;q++)
        {
                compare(c+q,q);
                printf("%s",*(c+q));
        }
        
}
void compare(char *c[],int n)
{
        int i = 0,j = 0;
        int max;
        int sum = 0;
        if(*c[n]>=65&&(*c[n]+1)>=97)
        {
                sum = strlen(c[n]);
                *c[n] = *c[n] + 32;
                for(i = 0;i<sum;i++)
                {
                        if(*c[i]==' ')
                        {
                                continue;
                        }
                        for(j = 1;j<sum;j++)
                        {
                                if(*c[j] == ' ')
                                {
                                        continue;
                                }
                                else if(*c[i]>*c[j])
                                {
                                        max = *c[i];
                                        *c[i] = *c[j];
                                        *c[j] = max;        
                                        
                                }        
                        }        
                } 
        }
        else
        {
                sum = strlen(c[n]);
                for(i = 0;i<sum;i++)
                {
                        for(j = 1;j<sum;j++)
                        {
                                if(*c[i]>*c[j])
                                {
                                        max = *c[i];
                                        *c[i] = *c[j];///////////////////字符串常量不可改变
                                        *c[j] = max;        
                                        
                                }        
                        }        
                } 
        }
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-2-12 19:54:58 | 显示全部楼层
真的迷在其中了,感觉很简单,就是找不出为啥一直提示那里错了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-2-12 19:56:12 | 显示全部楼层
麻了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-2-12 20:02:40 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jhq999 于 2022-2-12 20:04 编辑

字符串常量不允许修改
void compare(char *c[],int n);
#include <stdio.h>
#include <string.h>
int main()
{
        int q = 0;
        char *c[] = {"Follow me","BASIC","Great Wall","FORTRAN","Computer design"};/////////////////////////这里面都是字符串常量
        printf("这是按照要求排序后的字符串!\n\n");
        printf("%s\n\n",c[0]);//如果要输出一个字符串,使用%s,那么后面只能是地址c[0]
        printf("%c\n",*c[0]);//如果需要输出字符,那么需要加个星号,指向它输出! 
        for(q = 0;q<5;q++)
        {
                compare(c+q,q);
                printf("%s",*(c+q));
        }
        
}
void compare(char *c[],int n)
{
        int i = 0,j = 0;
        int max;
        int sum = 0;
        if(*c[n]>=65&&(*c[n]+1)>=97)
        {
                sum = strlen(c[n]);
                *c[n] = *c[n] + 32;
                for(i = 0;i<sum;i++)
                {
                        if(*c[i]==' ')
                        {
                                continue;
                        }
                        for(j = 1;j<sum;j++)
                        {
                                if(*c[j] == ' ')
                                {
                                        continue;
                                }
                                else if(*c[i]>*c[j])
                                {
                                        max = *c[i];
                                        *c[i] = *c[j];
                                        *c[j] = max;        
                                        
                                }        
                        }        
                } 
        }
        else
        {
                sum = strlen(c[n]);
                for(i = 0;i<sum;i++)
                {
                        for(j = 1;j<sum;j++)
                        {
                                if(*c[i]>*c[j])
                                {
                                        max = *c[i];
                                        *c[i] = *c[j];///////////////////字符串常量不可改变
                                        *c[j] = max;        
                                        
                                }        
                        }        
                } 
        }
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-2-13 15:05:53 | 显示全部楼层
本帖最后由 傻眼貓咪 于 2022-2-13 15:13 编辑

不知道是不是你要的:
#include <stdio.h>
#include <ctype.h>

void change(char[], size_t);
void swap(char*, char*);

int main() {
        char str[][20] = { "Follow me","BASIC","Great Wall","FORTRAN","Computer design" }; // <----- 注意这里 -----

        size_t
                N = sizeof(str) / sizeof(char[20]), // 数组长度
                n; // 字符串长度

        for (int i = 0; i < (int)N; i++) {
                n = sizeof(str[i]) / sizeof(char); // 字符串长度
                printf("%s -> ", str[i]);
                change(*(str + i), n); // 改变字符串字符循序
                printf("%s\n", str[i]);
        }
        return 0;
}

/* 改变字符串字符循序 */
void change(char str[], size_t n) {
        char a, b;
        for (size_t i = 0; i < n - 1; i++) {
                if (isalpha(str[i])) {
                        if (str[i] >= 'A' && str[i] <= 'Z') a = str[i] + ('a' - 'A');
                        else a = str[i];
                }
                else continue;
                for (size_t j = i + 1; j < n; j++) {
                        if (isalpha(str[j])) {
                                if (str[j] >= 'A' && str[j] <= 'Z') b = str[j] + ('a' - 'A');
                                else b = str[j];
                                if (a > b) swap(&(str[i]), &(str[j]));
                        }
                        else continue;
                }
        }
}

/* 字符交换位置 */
void swap(char* p, char* q) {
        char c = *p;
        *p = *q;
        *q = c;
}
Follow me -> eFmllo ow
BASIC -> ABCIS
Great Wall -> allae GrtW
FORTRAN -> ANFORRT
Computer design -> Cngiedes morptu
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-2-14 07:55:44 | 显示全部楼层
傻眼貓咪 发表于 2022-2-13 15:05
不知道是不是你要的:

谢谢你的帮助,不过,我的意思是不管是大小写字母,都安照26个英文字母顺序来排列。虽然没有符合预期,但是还是很谢谢你,我也发现了我的很多错误。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-2-14 07:58:07 | 显示全部楼层
jhq999 发表于 2022-2-12 20:02
字符串常量不允许修改

并没有实际解决问题,而且我也明白了直接差的还有一大截,不过我知道了自己那些地方还应该再看看书,谢谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-8 05:02

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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