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

#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);
}
}
原因找到了,是实参和形参的表示不对,还有数组作为参数的时候传递的是地址。

没见过这么但疼的程序,
一个函数干好一件事就行了,你直接来个大杂烩
蛋疼的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;
}
温馨提示:答案为网友推荐,仅供参考
第1个回答  2011-06-08
当输入的两组数gets(ch1); gets(ch2);
长度不相等,再次输入,直至两组相等才能跳出if(strlen(ch1)==strlen(ch2))
else
{
printf("你输入的字符串长度不相等,请再输入一次");
gets(ch1);
gets(ch2);
bijiao(a,b);
}
的循环,最后按两组数据的第一个字母大小比较,第一个字母大的那组数据先输出
第2个回答  2011-06-08
你的嵌套用的也太多了吧
想想其他复杂度小的方式吧
重构代码吧
第3个回答  2011-06-08
蛋疼啊。。。见楼上的吧
相似回答