繁体   English   中英

为什么我会在hackerrank中收到此消息“〜stdout无响应〜”? 我不知道我在想什么>

[英]Why am I getting this message in hackerrank “~ no response on stdout ~”? I don't know what I am missing>

为什么我在hackerrank中收到此消息“〜stdout无响应〜”? 我不知道我在想什么? 我现在有点沮丧,因为我不知道该怎么办。 因此,我只能选择在Stackoverflow上发布此查询。

这是问题的链接

这是我完整的代码:

char* readline();
// Complete the countingValleys function below.
int countingValleys(int n, char* s) 
{
  int dwnhl = 0, level = 0;
  bool frmsurface = true;
  int k = strlen(s);
  for (int i = 0; i < k; i++) 
  {
    if (level == 0) 
    {
      frmsurface = true;
    }

    if (s[i] == 'D') 
    {
      level--;
      if ((level < 0) && (frmsurface == true)) 
      {
        dwnhl++;
        frmsurface = false;
        //printf("went downhill %d ",i);
      }
    } 
    else if (s[i] == 'U') 
    { //printf("went uphill %d ",i);
      level++;
    }
    // printf("\nhello - %c",s[i]);
  }

  printf("\nNumber of downhill = %d \n", dwnhl);
  return (dwnhl);
}

int main() 
{
  FILE* fptr = fopen(getenv("OUTPUT_PATH"), "w");

  char* n_endptr;
  char* n_str = readline();
  int n = strtol(n_str, &n_endptr, 10);

  if (n_endptr == n_str || *n_endptr != '\0') 
  {
    exit(EXIT_FAILURE);
  }

  char* s = readline();

  int result = countingValleys(n, s);

  printf("%d\n", result);

  return 0;
}

char* readline() 
{
  size_t alloc_length = 1024;
  size_t data_length = 0;
  char* data = malloc(alloc_length);

  while (true) 
  {
    char* cursor = data + data_length;
    char* line = fgets(cursor, alloc_length - data_length, stdin);

    if (!line) 
    {
      break;
    }

    data_length += strlen(cursor);

    if (data_length < alloc_length - 1 || data[data_length - 1] == '\n') 
    {
      break;
    }

    size_t new_length = alloc_length << 1;
    data = realloc(data, new_length);

    if (!data) 
    {
      break;
    }

    alloc_length = new_length;
  }

  if (data[data_length - 1] == '\n') 
  {
    data[data_length - 1] = '\0';
  }

  data = realloc(data, data_length);

  return data;
}

一个问题是您处理frmsurface的方式

首次输入循环frmsurface将设置为true。 如果事件是UUDD ,则您的代码仍将算作一个“谷”,因为您在上时不清除frmsurface

代替

       if(level==0)               
       {                        
         frmsurface=true;     
       }

您可以尝试:

       frmsurface = (level == 0);

但我不太了解为什么要使用布尔值。 只需测试level == 0 就像是:

       if(s[i]=='D')  
       {
           if(level==0)
           {
               dwnhl++;
           }
           level--;
       }
       else if (s[i]=='U') 
       {
               level++;
       }

我也想知道这行:

printf("\nNumber of downhill = %d \n", dwnhl);

必须删除。

注意

   int k=strlen(s);
   for(int i=0;i<k;i++)

可能只是

   for(int i=0;i<n;i++)
                 ^

随着n传递给函数

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM