关于#死循环#的问题,如何解决?

这样不知道为什么进入死循环了,但是却如果去掉第七第八行,在for循环里把n初始化为0的时候又无法读取输入字符串的第一个字符,感谢大家

img

img

for循环里你要不断输入新的ch啊,不然肯定死循环啊,就输入了一个ch,玩到天荒地老了啊

循环条件修改为
(ch = getchar()) != '#'

你找个值承接变化的值,只有有条件限制,就不会死循环

  • 这篇文章讲的很详细,请看:矩阵乘法的实现(一般形式及单个矩阵的n次幂)
  • 除此之外, 这篇博客: 输入n个整数,按照绝对值从大到小排序后输出。题目保证对于每一个测试实例,所有的数的绝对值都不相等中的 输入数据有多组,每组占一行,每行的第一个数字为n,然后是n个整数,n= 0表示输入数据的结束,不做处理。对于每个测试实例,输出排序后的结果,两个数之间用一个空格替换。每个测试实例占一行。 部分也许能够解决你的问题, 你可以仔细阅读以下内容或跳转源博客中阅读:
  • #include<stdio.h>
    #include<math.h>
    int main()
    {
     int i,j,m,n,t,a[1000];
     while(scanf("%d",&n)!=EOF)//多次输入
     {
      if(n==0)//如果输入的数为0结束输入
       break;
      for(i=1;i<=n;i++)//把输入的n个整数存入数组中
      {
       scanf("%d",&m);
       a[i]=m;
      }
      for(j=n;j>0;j--)//用冒泡排序法把n个整数按绝对值的大小从大到小排序
      {
         for(i=j-1;i>0;i--)
         {
        if(fabs(a[j])>fabs(a[i]))//调用计算绝对值函数比较它们的绝对值的大小
        {
         t=a[j];
         a[j]=a[i];
         a[i]=t;
        }
       }
      }
       for(i=1;i<=n;i++)//把排序后的数组输出
       {
        if(i!=n)
        printf("%d ",a[i]);
        else
         printf("%d\n",a[i]);
       }
     }
        return 0;
    }