作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在编写这个冒泡排序练习,并且必须创建 2 个源文件。第一个包含主要代码,第二个包含我的冒泡排序算法。主要代码包括冒泡排序。
主要:
#include<stdio.h>
#include<string.h>
#include"2.c"
int main(void)
{
char text[100];
int length;
printf("Insert text: \n");
gets(text);
text=bsort(text);
printf("String : %s \n",text);
return 0;
}
冒泡排序:
char *bsort(char text[100]){
char temp[100];
int length,i,j;
length=strlen(text);
for(i=1;i<length;i++){
for(j=0;j<length-i;j++){
if(text[j]>text[j+1]){
temp[0]=text_input[j]; //
text_input[j]=text_input[j+1];//Edit,had wrong code posted
text_input[j+1] =temp[0]; //
}
}
}
return text;}
问题是,当我运行它时,我收到“从类型 'char *' 分配给类型 'char[100]' 时出现不兼容的类型”错误
我对 c 非常陌生,我有点迷失了,我现在正在浏览答案几个小时。我知道该函数将返回一个 char 而不是 char 数组(根据 java 经验称为字符串),但我只是无法尽我所能找到一种方法来做到这一点。
一个解决方案会很棒,或者只是一个小小的帮助,我们将不胜感激。
编辑:我忘了提及我的程序实际上是做什么的。它应该从用户那里获取一个字符串,应用冒泡排序算法,该算法将按字母顺序对字符串中的每个字符进行排序,即“bagf”将输出为“abfg”。还添加了一些评论
最佳答案
首先请以可读的方式编写您的代码,您的问题是您没有交换任何值
char *bsort(char text[100])
{
char temp[100];
int length, i, j;
length = strlen(text);
for(i = 1 ; i < length ; i++)
{
for (j = 0 ; j < length - i ; j++)
{
if(text[j] > text[j + 1])
{
temp[0] = text[j];
text[j] = text[j+1];
text[j + 1] = temp[0];
}
}
}
return text;
}
关于c - 如何从 C 中的 char 函数返回字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28953250/
我是一名优秀的程序员,十分优秀!