2021年4月8日 今日成果

目录

一:[COCI2019-2020#1] Lutrija - 洛谷

 第一次提交代码

第二次提交代码

 第三次提交代码

 等比赛结束继续


一:[COCI2019-2020#1] Lutrija - 洛谷

第一次提交 16分  第二次提交还是16分 第三次提交52分

 第一次提交代码

#include<bits/stdc++.h>
using namespace std;
long long n,m;
int ans[30];
bool flag;
bool is_prime(long long x)
{
switch(x)
    {
case 1:
    return false;
    break;
case 2:
    return true;
    break;
default:
    for(int i = 2;i<=sqrt(x);i++)
    {
        if(x%i==0)
            return true;
        else
            return false;
    }
    break;
    }
}
void dfs(int l,int r,int d)
{
    if(d == 30 || flag == true)
        return;
if(is_prime(fabs(l-r)))
	{
		cout<<d+1<<endl;
		cout<<n<<" ";
		for(int i=0;i<d-1;i++)
            cout<<ans[i]<<endl;
		cout<<m<<endl;
        flag=1;
        return;
	return ;
	}

    if(l!=2)
    {
        if(is_prime(l-2))
        {
            ans[d]=2;
            dfs(2,r,d+1);
        }
        if(is_prime(l-2))
        {
            ans[d]=l-2;
            dfs(l-2,r,d+1);
        }
        if(is_prime(l+2))
        {
            ans[d]=l+2;
            dfs(l+2,r,d+1);
        }
    }
    else
    {
        if(is_prime(r+2))
        {
            ans[d]=r+2;
            dfs(r+2,r,d+1);
        }
    }
return;
}



int main()
{
        cin>>n>>m;
        dfs(n,m,1);
        if(flag==false)
        {
            cout<<"-1";
        }
        return 0;
}

第二次提交代码

is_prime的bug

#include<bits/stdc++.h>
using namespace std;
long long n,m;
int ans[30];
bool flag = 0;
bool is_prime(long long x)
{
  //  cout<<x<<" ";
switch(x)
    {
case 1:
    return false;
case 2:
    return true;
default:
    for(int i = 2;i*i<=x;i++)
    {
        if(x%i==0){
            return false;
        }
        }
        return true;
    }
}
void dfs(int l,int r,int d)
{
    if(d == 30 || flag == true)
        return;
if(is_prime(abs(l-r)))
	{
		cout<<d+1<<endl;
		cout<<n<<" ";
		for(int i=1;i<d-1;i++)
            cout<<ans[i]<<endl;
		cout<<m<<endl;
        flag=1;
        return;
	return ;
	}
cout<<l<<" "<<r<<endl;
    if(l!=2)
    {
        if(is_prime(l-2))
        {
            ans[d]=2;
            dfs(2,r,d+1);
        }
        if(is_prime(l-2))
        {
            ans[d]=l-2;
            dfs(l-2,r,d+1);
        }
        if(is_prime(l+2))
        {
            ans[d]=l+2;
            dfs(l+2,r,d+1);
        }
    }
    else
    {
        if(is_prime(r+2))
        {
            ans[d]=r+2;
            dfs(r+2,r,d+1);
        }
    }
}



int main()
{
        cin>>n>>m;
        dfs(n,m,1);
       // cout<<flag;
        if(flag==false)
        {
            cout<<"-1";
        }
        return 0;
}

 第三次提交代码

忘了注释掉测试代码

#include<bits/stdc++.h>
using namespace std;
long long n,m;
int ans[30];
bool flag = 0;
bool is_prime(long long x)
{
   // cout<<x<<" ";
switch(x)
    {
case 1:
    return false;
case 2:
    return true;
default:
    for(int i = 2;i*i<=x;i++)
    {
        if(x%i==0){
            return false;
        }
        }
        return true;
        break;
    }
}
void dfs(int l,int r,int d)
{
    if(d == 30 || flag == true)
        return;
if(is_prime(abs(l-r)))
	{
		cout<<d+1<<endl;
		cout<<n<<" ";
		for(int i=1;ans[i]!=0;i++)
            cout<<ans[i]<<" ";
		cout<<m<<endl;
        flag=1;
        return;
	return ;
	}
//cout<<l<<" "<<r<<endl;
    if(l!=2)
    {
        if(is_prime(l-2))
        {
            ans[d]=2;
            dfs(2,r,d+1);
        }
        if(is_prime(l-2))
        {
            ans[d]=l-2;
            dfs(l-2,r,d+1);
        }
        if(is_prime(l+2))
        {
            ans[d]=l+2;
            dfs(l+2,r,d+1);
        }
    }
    else
    {
        if(is_prime(r+2))
        {
            ans[d]=r+2;
            dfs(r+2,r,d+1);
        }
    }
}



int main()
{
        cin>>n>>m;
        dfs(n,m,1);
       // cout<<flag;
        if(flag==false)
        {
            cout<<"-1";
        }
        return 0;
}

 等比赛结束继续

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值