c - HackerEarth女朋友的需求挑战

标签 c algorithm runtime-error time-complexity

问题描述可参见Here 。我的程序正在生成与示例测试用例匹配的输出,但是当遇到大整数时,程序崩溃了,我无法找出原因。当用户提供的数据类似于 a:=252509054433933447 b:=760713016476190629 时,程序要么停止响应,要么收到 SIGABRT 错误或处理时间1 个输入文件超出最大分配时间。我的代码有什么问题吗?有人能建议一个更好的算法来做到这一点吗?请帮我找出错误。

#include<stdio.h>
#include<string.h>
int main()
{
      long long int a,b,input,len,len1,len2;
      char dem[1000];
      char temp[100000];
      scanf("%s",dem);
      scanf("%u",&input);

      len=strlen(dem);

      for(unsigned int i=0;i<input;i++)
      {
        scanf("\n%lld %lld",&a,&b);

        if(b>len)
        {
          len1=b/len;
          for(unsigned int j=1;j<=((len1+1));j++)
          {
          strcat(temp,dem);
          }
         }
         else
         {
            if(dem[a-1]==dem[b-1])
            {
             printf("\nYes");
            }
            else
            {
              printf("\nNo");
            } 
         }
        len2=strlen(temp);
        if(len2!=0)
        {
        if(temp[a-1]==temp[b-1])
        {
          printf("\nYes");
        }
        else
        {
          printf("\nNo");
        }
        }  

        }

}

最佳答案

哇,这是一个厌恶女性的问题描述。太遗憾了。

您的问题在这里:

for(unsigned int j=1;j<=((len1+1));j++)
{
   strcat(temp,dem);
}

您不应该将给定字符串与其自身连接起来,这将不适合给定限制的内存。相反,如果您确实进行了串联,请尝试使用模运算来查找某个位置上的字符。

例如,如果您有字符串 abc,我问,通过无限次重复 abc 形成的字符串中位置 10 的字符是什么,您'd do(从零开始的索引):

char_at_position = str[10 % len(abc)] = str[10 mod 3] = str[1] = b

0123456789 10
abcabcabca b  c
           *

关于c - HackerEarth女朋友的需求挑战,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28542919/

相关文章:

c - 指针最佳实践

algorithm - 大 O 型术语,但保持不变

javascript - 处理哈希数据的最佳算法

user-interface - 如何使用搜索选项修复 Gui 的 netbeans 中的运行时错误?

java - Java越界错误

cmake 命令行选项

c - 此代码适用于 C++,知道如何将此代码转换为 C,因为在 C 中语法完全不同

c - 线程程序问题

javascript - 是否有已知的算法来检测确保形状连续性所需的像素?

javascript - 通过 JavaScript 创建新的 HTML5 视频元素