开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 935|回复: 7
收起左侧

[C/C++] 这是哪儿出问题了?C++题目

[复制链接]
结帖率:69% (9/13)
发表于 2023-1-11 11:19:19 | 显示全部楼层 |阅读模式   广东省佛山市
5精币
113.png
我的代码:
#include<bits/stdc++.h>
using namespace std;
int n;
int pd(int x)
{
        int a[100000];
        for(int i=2;i<=x;i++)
        {
                if(a==0)
                    for(int j=i+i;j<=10000;j+=i)
                        a[j]=i;
        }
        if(a[x]==0)return 1;
        return 2;
}
int main()
{
        int hh=0;
        scanf("%d",&n);            
    for(int i=4;i<=n;i++)
    {
            int q=i,q1=i,x=0;
            int ans1=0,ans2=0;
            while(q>0)
            {
                    ans1+=q%10;
                    q/=10;
                }
                while(q1>1)
                {
                        x=2;
                        while(q1%x!=0)
                            x++;
                        if(x>=10)ans2+=x/10+x%10;
                        else ans2+=x;
                        q1/=x;
                }
                //cout<<ans2<<" ";
                //cout<<ans1<<" "<<ans2<<"|";
                if(ans1==ans2&&pd(i)==2)
                    cout<<i<<" ",hh++;
                if(hh==5)
                {
                        cout<<endl;
                        hh=0;
                }
        }
        return 0;
}
不知道为什么只拿了20分,满分是100分,求大佬帮忙看看



回答提醒:如果本帖被关闭无法回复,您有更好的答案帮助楼主解决,请发表至 源码区 可获得加分喔。
友情提醒:本版被采纳的主题可在 申请荣誉值 页面申请荣誉值,获得 1点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。
快捷通道:申请荣誉值无答案申请取消悬赏投诉有答案未采纳为最佳
结帖率:69% (9/13)
 楼主| 发表于 2023-1-11 11:26:39 | 显示全部楼层   广东省佛山市
现在是80分了,解决了一个问题,但还有个问题
#include<bits/stdc++.h>
using namespace std;
int n;
int pd(int x)
{
        int a[100000];
        for(int i=2;i<=x;i++)
        {
                if(a[i]==0)
                    for(int j=i+i;j<=100000;j+=i)
                        a[j]=i;
        }
        if(a[x]==0)return 1;
        return 2;
}
int main()
{
        int hh=0;
        scanf("%d",&n);            
    for(int i=4;i<=n;i++)
    {
            int q=i,q1=i,x=0;
            int ans1=0,ans2=0;
            while(q>0)
            {
                    ans1+=q%10;
                    q/=10;
                }
                while(q1>1)
                {
                        x=2;
                        while(q1%x!=0)
                            x++;
                        if(x>=10)
                        {
                                int q3=x;
                                while(q3>0)
                    {
                            ans2+=q3%10;
                            q3/=10;
                        }
                        }
                        else ans2+=x;
                        q1/=x;
                }
                //cout<<ans2<<" ";
                //cout<<ans1<<" "<<ans2<<"|";
                if(ans1==ans2&&pd(i)==2)
                {
                        printf("%d ",i);
                        hh++;
                }
                if(hh==5)
                {
                        printf("\n");
                        hh=0;
                }
        }
        return 0;
}
回复

使用道具 举报

发表于 2023-1-11 11:55:33 | 显示全部楼层   山西省晋中市
什么网站
回复

使用道具 举报

结帖率:69% (9/13)
 楼主| 发表于 2023-1-11 12:00:20 | 显示全部楼层   广东省佛山市

冬令营,网址不方便发
回复

使用道具 举报

结帖率:100% (21/21)

签到天数: 10 天

发表于 2023-1-11 12:46:57 | 显示全部楼层   山西省运城市
你最后拿不上分的那4个点错误原因是啥,时间超了还是说值错了
回复

使用道具 举报

结帖率:69% (9/13)
 楼主| 发表于 2023-1-11 13:31:46 | 显示全部楼层   广东省佛山市
moys520 发表于 2023-1-11 12:46
你最后拿不上分的那4个点错误原因是啥,时间超了还是说值错了

时间超时
回复

使用道具 举报

结帖率:100% (21/21)

签到天数: 10 天

发表于 2023-1-11 17:59:10 | 显示全部楼层   山西省运城市

改用stl试试吧,思路我没看出来有啥问题

补充内容 (2023-1-11 17:59):
只能回忆起以前被信竟支配的恐惧
回复

使用道具 举报

结帖率:100% (13/13)

签到天数: 1 天

发表于 2023-3-10 23:49:55 | 显示全部楼层   江苏省徐州市
[C++] 纯文本查看 复制代码
这段代码的问题在于pd函数中的素数筛选不正确,导致在判断一个数是否为素数时出现了错误。具体来说,问题出现在以下代码段:

int a[100000];
for(int i=2;i<=x;i++)
{
  if(a==0) // 这里应该是a==0
    for(int j=i+i;j<=10000;j+=i)
      a[j]=i;
}
在这段代码中,你声明了一个数组a,然后进行了筛选,将数组中的合数标记为其最小质因子。然而,在筛选的过程中,你使用了一个错误的判断条件a==0,应该改为a==0。因为你想要判断第i个数是否是质数,而不是判断a数组是否为0。

因此,修改后的pd函数应该如下所示:

int pd(int x)
{
  int a[100000];
  memset(a, 0, sizeof(a)); // 初始化为0
  for (int i = 2; i <= x; i++)
  {
    if (a == 0) // 判断a是否已经被标记过
      for (int j = i + i; j <= x; j += i)
        a[j] = i;
  }
  if (a[x] == 0)
    return 1;
  return 2;
}
此外,你在判断一个数是否为“吉祥数”时,只检查了该数是否为素数,然而这并不足以保证它是“吉祥数”。因此,你需要在判断时同时验证该数的各位数字之和是否等于其各个质因子(如果有的话)的各位数字之和。修改后的代码如下:

int pd(int x)
{
  int a[100000];
  memset(a, 0, sizeof(a)); // 初始化为0
  for (int i = 2; i <= x; i++)
  {
    if (a == 0) // 判断a是否已经被标记过
      for (int j = i + i; j <= x; j += i)
        a[j] = i;
  }
  
  // 判断各位数字之和是否等于各个质因子的各位数字之和
  int sum1 = 0, sum2 = 0;
  int tmp = x;
  while (tmp > 0)
  {
    sum1 += tmp % 10;
    tmp /= 10;
  }
  tmp = x;
  while (tmp > 1)
  {
    int factor = a[tmp] == 0 ? tmp : a[tmp];
    int factor_sum = 0;
    while (factor > 0)
    {
      factor_sum += factor % 10;
      factor /= 10;
    }
    sum2 += factor_sum;
    tmp /= factor;
  }
  
  if (a[x] == 0 && sum1 == sum2)
    return 1;
  return 2;
}
经过以上修改,你的程序应该可以得到满分了。

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 诚聘英才| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 800073686,邮箱:800073686@b.qq.com
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表