C语言问题,高手帮忙解答一下,要一次说出答案,要追问的走开。

#include<stdio.h>#include"string.h"voidmain(){charch1[100],ch2[100],a,b;intflag,i=0;i... #include<stdio.h>
#include "string.h"
void main()
{
char ch1[100],ch2[100],a,b;
int flag,i=0;
int bijiao(char a,char b);
printf("请输入2串等长度的字符串,长度小于100 \n");
gets(ch1);
gets(ch2);
flag=bijiao(a,b);
}
static int bijiao(char a,char b)
{
extern char ch1[100],ch2[100];
extern int flag;
if(strlen(ch1)==strlen(ch2))
{
int i=0,flag;
while(ch1[i++]!='\0'&&ch2[i++]!='\0')
{
if(ch1[i-1]<ch2[i-1])
{
flag=-1;
break;
}

if(ch1[i-1]>ch2[i-1])
{
flag=1;
break;
}
else
flag=0;
}
}
else
{
printf("你输入的字符串长度不相等,请再输入一次");
gets(ch1);
gets(ch2);
bijiao(a,b);
}
if(flag==1)
{
puts(ch1);
puts(ch2);
}
if(flag==-1)
{
puts(ch2);
puts(ch1);
}
}
原因找到了,是实参和形参的表示不对,还有数组作为参数的时候传递的是地址。
展开
 我来答
crab2313
2011-06-08 · TA获得超过255个赞
知道小有建树答主
回答量:346
采纳率:0%
帮助的人:283万
展开全部
没见过这么但疼的程序,
一个函数干好一件事就行了,你直接来个大杂烩
蛋疼的static和extern
长度相不相等别处判断去
你是比较a,b还是ch1,ch2啊
我这里编译都过不去
#include <stdio.h>
#include <string.h>
void main()
{
char ch1[100],ch2[100];
int flag, i = 0;
printf("请输入2串等长度的字符串,长度小于100 \n");
gets(ch1);
gets(ch2);
flag = bijiao(ch1,ch2);
}

int bijiao(char *ch1, char *ch2)
{
int i = 0, flag;
while (ch1[i++] != '\0' && ch2[i++] != '\0') {
if (ch1[i - 1] < ch2[i - 1]) {
flag = -1;
break;
}

if (ch1[i - 1] > ch2[i - 1]) {
flag = 1;
break;
} else
flag = 0;
}
return flag;
}
zyzsy1234
2011-06-08
知道答主
回答量:10
采纳率:0%
帮助的人:6万
展开全部
当输入的两组数gets(ch1); gets(ch2);
长度不相等,再次输入,直至两组相等才能跳出if(strlen(ch1)==strlen(ch2))
else
{
printf("你输入的字符串长度不相等,请再输入一次");
gets(ch1);
gets(ch2);
bijiao(a,b);
}
的循环,最后按两组数据的第一个字母大小比较,第一个字母大的那组数据先输出
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
啪啦图
2011-06-08 · TA获得超过112个赞
知道小有建树答主
回答量:309
采纳率:0%
帮助的人:162万
展开全部
你的嵌套用的也太多了吧
想想其他复杂度小的方式吧
重构代码吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
first1bingo
2011-06-08
知道答主
回答量:44
采纳率:0%
帮助的人:0
展开全部
蛋疼啊。。。见楼上的吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式