当前位置: 代码迷 >> C语言 >> 求输入一个二维字符数组中的最大字母并输出所在的行与列
  详细解决方案

求输入一个二维字符数组中的最大字母并输出所在的行与列

热度:144   发布时间:2006-05-09 17:25:00.0
求输入一个二维字符数组中的最大字母并输出所在的行与列

#include <stdio.h>
#include <string.h>

main ()
{
char a[2][80], t;
int r, j, m, n, L, max;

for (r = 0; r <= 1; r++)
gets (a[r]);
t = a[0][0];

for (r = 0; r <= 1; r++)
{
L = strlen (a[r]);
for (j = 0; j <= L; j++)
if (a[r][j] > t)
{
max = a[r][j];
max = t;
m = r;
n = j;
}
}
printf ("max=%c row=%d colum=%d\n", max, m, n);
getch ();
return 0;
}

输出结果不对?

搜索更多相关的解决方案: 字母  字符  输出  include  输入  

----------------解决方案--------------------------------------------------------
最大字母指什么,最大不就'Z'吗,还有比它大的
----------------解决方案--------------------------------------------------------

#include <stdio.h>
#include <conio.h>
#define N 3
#define M 30

int main(void)
{
char str[N][M], ch;
int i, j, row = 0, column = 0;

for (i = 0; i < N; i++)
{
gets(str[i]);
}

ch = str[row][column];

for (i = 0; i < N; i++)
{
for (j = 0; str[i][j] != '\0'; j++)
{
if (str[i][j] > ch)
{
ch = str[i][j];
row = i;
column = j;
}
}
}

printf("ch = %c\n", ch);
printf("row = %d\n", row);
printf("column = %d\n", column);

getch();
return 0;
}


----------------解决方案--------------------------------------------------------

#include <stdio.h>
#include <conio.h>

main ()
{
char a[2][80], t;
int r, j, m = 0, n = 0;

for (r = 0; r <= 1; r++)
gets (a[r]);
t = a[m][n];

for (r = 0; r <= 1; r++)
{
for (j = 0; a[r][j] != '\0'; j++)
if (a[r][j] > t)
{
t = a[r][j];
m = r;
n = j;
}
}
printf ("max=%c row=%d colum=%d\n", t, m, n);

getch ();
return 0;
}

[此贴子已经被作者于2006-5-9 18:40:16编辑过]


----------------解决方案--------------------------------------------------------
楼上的,
如果最大的字母有重复的不能统计出来.
如输入.
word
sow
----------------解决方案--------------------------------------------------------

只是对 论坛 那位兄弟的程序进行了针对性整理,这会应该没问题拉!
但可能不是很精练!

#include <stdio.h>
#include <conio.h>

main ()
{
char a[2][80], t;
int r, j, m = 0, n = 0;

for (r = 0; r <= 1; r++)
gets (a[r]);
t = a[m][n];

for (r = 0; r <= 1; r++)
{
for (j = 0; a[r][j] != '\0'; j++)
if (a[r][j] > t)
{
t = a[r][j];
}
}
printf ("max='%c' :\n", t);
for (r = 0; r <= 1; r++)
{
for (j = 0; a[r][j] != '\0'; j++)
if (a[r][j]==t)
{
m = r;
n = j;
printf (" row=%d colum=%d\n", m, n);
}
}
getch ();
return 0;
}


----------------解决方案--------------------------------------------------------
你管它重复不重复干嘛,重复它只有一个最大的,不重复它也只有一个最大的,求出第一个不就完了吗
----------------解决方案--------------------------------------------------------
你求那么干嘛,最大的不就一个吗
----------------解决方案--------------------------------------------------------
等着我的帖子吧!
----------------解决方案--------------------------------------------------------
多谢6楼的..cdmalcl
----------------解决方案--------------------------------------------------------
  相关解决方案