C语言程序问题?
#include<stdio.h>#defineN4voidfun(inta[][N],intb[],intflag){inti,j;for(i=0;i<N;i++){b...
#include <stdio.h>
#define N 4
void fun(int a[][N], int b[], int flag)
{ int i,j;
for(i=0; i<N; i++)
{ b[i] = a[i][0];
for(j=1; j<N; j++)
if (flag ? (b[i] > a[i][j]) : (b[i] < a[i][j]))
b[i] = a[i][j];
}
}
main( )
{ int x[N][N]={1, 2, 3, 4, 5, 6, 7, 8, 9,10,11,12,13,14,15,16}, y[N],i;
fun(x, y, 1);
for ( i=0; i<N; i++ ) printf("%d,", y[i]);
fun(x, y, 0);
for (i=0;i<N; i++) printf("%d,", y[i]);
printf("\n");
}
f (flag ? (b[i] > a[i][j]) : (b[i] < a[i][j]))
这一段代码有什么用?
flag一直是1,那返回的结果就一直是“b[i] > a[i][j]”?
可是这个“b[i] > a[i][j]”有什么用? 展开
#define N 4
void fun(int a[][N], int b[], int flag)
{ int i,j;
for(i=0; i<N; i++)
{ b[i] = a[i][0];
for(j=1; j<N; j++)
if (flag ? (b[i] > a[i][j]) : (b[i] < a[i][j]))
b[i] = a[i][j];
}
}
main( )
{ int x[N][N]={1, 2, 3, 4, 5, 6, 7, 8, 9,10,11,12,13,14,15,16}, y[N],i;
fun(x, y, 1);
for ( i=0; i<N; i++ ) printf("%d,", y[i]);
fun(x, y, 0);
for (i=0;i<N; i++) printf("%d,", y[i]);
printf("\n");
}
f (flag ? (b[i] > a[i][j]) : (b[i] < a[i][j]))
这一段代码有什么用?
flag一直是1,那返回的结果就一直是“b[i] > a[i][j]”?
可是这个“b[i] > a[i][j]”有什么用? 展开
3个回答
展开全部
第一题,使用结构体定义个人,并用循环嵌套找出顺序,试着写了一下,由于我不太擅长,功能上虽然实现了,但估计还会有更多更好的方法,呵呵,还请见谅。
#include
void
main()
{
int
i,j;
struct
eater
{
char
name;
//人名
int
eat;
//饭量
int
lie;
//话中的谎言数
};
struct
eater
e[3];
e[0].name='A';
e[1].name='B';
e[2].name='C';
bool
getIt=false;
//用于跳出多重循环,也可使用goto
for(e[0].eat=0;e[0].eat<3;e[0].eat++)
{
for(e[1].eat=0;e[1].eat<3;e[1].eat++)
{
for(e[2].eat=0;e[2].eat<3;e[2].eat++)
{
e[0].lie=e[1].lie=e[2].lie=2;
if(e[1].eat>e[0].eat)
e[0].lie--;
if(e[2].eat==e[0].eat)
e[0].lie--;
if(e[0].eat>e[1].eat)
e[1].lie--;
if(e[0].eat>e[2].eat)
e[1].lie--;
if(e[2].eat>e[1].eat)
e[2].lie--;
if(e[2].eat>e[0].eat)
e[2].lie--;
if(e[0].eat==e[0].lie&&e[1].eat==e[1].lie&&e[2].eat==e[2].lie)
{
getIt=true;
break;
}
}
if(getIt)
break;
}
if(getIt)
break;
}
for(i=0;i<3;i++)
printf("%c
的饭量是
%d.\n",e[i].name,e[i].eat);
printf("按饭量大小排序为:");
for(i=2;i>=0;i--)
for(j=0;j<3;j++)
if(e[j].eat==i)
printf("%c
",e[j].name);
}
第二题思路差不多了,估计对预言进行组合,比对名次进行全排列有效。要是想讨论一下可以百度hi我。C老久不写,手生了,这些问题如果用对象解决能简单得多。
#include
void
main()
{
int
i,j;
struct
eater
{
char
name;
//人名
int
eat;
//饭量
int
lie;
//话中的谎言数
};
struct
eater
e[3];
e[0].name='A';
e[1].name='B';
e[2].name='C';
bool
getIt=false;
//用于跳出多重循环,也可使用goto
for(e[0].eat=0;e[0].eat<3;e[0].eat++)
{
for(e[1].eat=0;e[1].eat<3;e[1].eat++)
{
for(e[2].eat=0;e[2].eat<3;e[2].eat++)
{
e[0].lie=e[1].lie=e[2].lie=2;
if(e[1].eat>e[0].eat)
e[0].lie--;
if(e[2].eat==e[0].eat)
e[0].lie--;
if(e[0].eat>e[1].eat)
e[1].lie--;
if(e[0].eat>e[2].eat)
e[1].lie--;
if(e[2].eat>e[1].eat)
e[2].lie--;
if(e[2].eat>e[0].eat)
e[2].lie--;
if(e[0].eat==e[0].lie&&e[1].eat==e[1].lie&&e[2].eat==e[2].lie)
{
getIt=true;
break;
}
}
if(getIt)
break;
}
if(getIt)
break;
}
for(i=0;i<3;i++)
printf("%c
的饭量是
%d.\n",e[i].name,e[i].eat);
printf("按饭量大小排序为:");
for(i=2;i>=0;i--)
for(j=0;j<3;j++)
if(e[j].eat==i)
printf("%c
",e[j].name);
}
第二题思路差不多了,估计对预言进行组合,比对名次进行全排列有效。要是想讨论一下可以百度hi我。C老久不写,手生了,这些问题如果用对象解决能简单得多。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这个应该是判断条件有问题,那个判断形式应该是?前后返回的是判断条件为真的时候的值,后面返回的是判断条件不成立的时候的值,你这个写法根本没有改变flag的值,因为根本就没有做赋值的操作。
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
fun(x,y,1)求每一行的最小值放进y[]里面
fun(x,y,0)求每一行的最大值放进y[]里面
fun(x,y,0)求每一行的最大值放进y[]里面
更多追问追答
追问
可是,哥,我有点不太懂。
if (flag ? (b[i] > a[i][j]) : (b[i] a=2,是不成立的。
那,“b[i] > a[i][j]”,返回的是什么值?
我不明白这个返回值,弄不清程序接下来怎么循环。
追答
flag由函数参数传入,当传入1时,那条语句相当于if(b[i] > a[i][j])b[i]=a[i][j];
当传入0时,那条语句相当于if(b[i] < a[i][j])b[i]=a[i][j];
循环④次比较a[i][j] j=0,1,2,3后 b[i]里放的就是a[i][1....4]里面最大(最小的值了)
如果bi比a[i][j]小,b就赋予a[i][j]那b最后就是a[i][j]里面最大的了。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询