|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
我实在是找不出问题所在,这是我自己打的,找过网上的代码,差不多的思路。运行的时候,有时候是正确的,有时候又出问题.....#include<stdio.h>
main()
{
int n,i,j,k;
int a[6][6];
scanf("%d",&n);
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
scanf("%d",&a[i][j]);
}
}
for(i=1;i<n;i++)
{
for(j=0;j<i;j++)
{
if(a[i][j]!=0)
{
k=1;
}
}
}
if(k)
{
printf("NO");
}
else
{
printf("YES");
}
return 0;
}
本帖最后由 肖-肖 于 2021-5-18 22:12 编辑
首先你这个代码是用来判断你输入的矩阵是不是上三角矩阵的代码,而不是用来求上三角形矩阵的
我改了下代码主要还是用getchar()接收下每行输入完的回车
注释中也有解释的为什么那么写
具体代码如下:
- #include<stdio.h>
- int main()
- {
- int n,i,j,k=0;
- int a[6][6];
- //scanf("%d",&n);//既然给定了是6行6列的数组那么不要输入了直接用i<6即可
- for(i=0;i<6;i++)
- {
- for(j=0;j<6;j++)
- {
- scanf("%d",&a[i][j]);
- }
- getchar();//接收下每行的回车
- }
- for(i=1;i<6;i++)
- {
- for(j=0;j<i;j++)
- {
- if(a[i][j]!=0)
- {
- k=1;
- break;
- }
- }
- }
- if(k)
- {
- printf("NO");
- }
- else
- {
- printf("YES");
- }
- return 0;
- }
复制代码
运行效果如下:
不是上三角形矩阵的验证图如下:
|
|