马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 铭凡 于 2023-1-7 21:12 编辑
小甲鱼老师的问题如下:
2. 每一个好的品牌都有一个耳熟能详的 Slogan(口号)。写一个程序,让用户输入 5 句话,并计算出最长和最短的两句。
要求 A:使用 1 个二维数组存储用户输入的 5 句话。
要求 B:结果打印格式如下图。
然后这个是标准答案:
#include <stdio.h>
#include <string.h>
#define NUM 5
int main()
{
char slogan[NUM][100];
int i, j, ch, min, max, temp;
for (i = 0; i < NUM; i++)
{
printf("请输入%d句话:", i+1);
for (j = 0; (ch = getchar()) != '\n'; j++)
{
slogan[i][j] = ch;
}
slogan[i][j] = '\0';
}
min = 0;
max = min;
printf("你输入了下边%d句话:\n", NUM);
// 打印每句口号,同时比较长度
for (i = 0; i < NUM; i++)
{
printf("%s\n", slogan[i]);
temp = strlen(slogan[i]);
min = temp < strlen(slogan[min]) ? i : min;
max = temp > strlen(slogan[max]) ? i : max;
}
printf("其中最长的是:%s\n", slogan[max]);
printf("其中最短的是:%s\n", slogan[min]);
return 0;
}
这个是我的答案:
#include <stdio.h>
#include <string.h>
int main(void)
{
char str[5][50];
int i;
int j;
for(i = 0; i < 5; i++)
{
printf("请输入第%d句话: ", i + 1);
for(j = 0; (str[i][j] = getchar()) != '\n'; j++)
{
;
}
str[i][j] = '\0';
}
int length[5];
for(i = 0; i < 5; i++)
{
length[i] = strlen(str[i]);
}
int min = 0;
int max = 0;
for(i = 1; i < 5; i++)
{
if(length[i] < min)
{
min = i;
}
}
for(i = 1; i < 5; i++)
{
if(length[i] > max)
{
max = i;
}
}
printf("你输入了下边5句话: \n");
for(i = 0; i < 5; i++)
{
printf("%s\n", str[i]);
}
printf("其中最长的是: %s\n", str[max]);
printf("其中最短的是: %s\n", str[min]);
return 0;
}
提问:请大家注意比较长度这里的逻辑有没有问题
下面附上两张实际操作图
图1
这个是我用数字测试的
图2
我按照课后作业的样子输入句子之后,最长的和最短的就交换位置了。。。
求解,谢谢各位大神!
#include <stdio.h>
#include <string.h>
int main(void)
{
char str[5][50] = {};
int i;
int j;
for(i = 0; i < 5; i++)
{
printf("请输入第%d句话: ", i + 1);
for(j = 0; (str[i][j] = getchar()) != '\n'; j++)
{
;
}
str[i][j] = '\0';
}
int length[5];
for(i = 0; i < 5; i++)
{
length[i] = strlen(str[i]);
}
int min = 0, minval = 10000;
int max = 0, maxval = 0;
for(i = 0; i < 5; i++)
{
if(length[i] < minval)
{
min = i;
minval = length[i];
}
}
for(i = 0; i < 5; i++)
{
if(length[i] > maxval)
{
max = i;
maxval = length[i];
}
}
printf("你输入了下边5句话: \n");
for(i = 0; i < 5; i++)
{
printf("%s\n", str[i]);
}
printf("其中最长的是: %s\n", str[max]);
printf("其中最短的是: %s\n", str[min]);
return 0;
}
|