开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 2831|回复: 11
收起左侧

[已解决] 程序大赛的又一道题,C++高手快进!!

 关闭 [复制链接]
结帖率:56% (5/9)
发表于 2011-3-26 10:02:40 | 显示全部楼层 |阅读模式   湖南省娄底市
2精币
题目四:(9分)
1.        问题描述:
大于1 的正整数n可以分解为:n=x1*x2*…*xm。例如,当n=12 时,共有8 种不同的分解式:
12=12;
12=6*2;
12=4*3;
12=3*4;
12=3*2*2;
12=2*6;
12=2*3*2;
12=2*2*3。
2.        要求:3
    对于给定的正整数n,编程计算n共有多少种不同的分解式

最佳答案

查看完整内容

#include using namespace std; int main() { int a,b,c,d; cout

回答提醒:如果本帖被关闭无法回复,您有更好的答案帮助楼主解决,请发表至 源码区 可获得加分喔。
友情提醒:本版被采纳的主题可在 申请荣誉值 页面申请荣誉值,获得 1点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。
快捷通道:申请荣誉值无答案申请取消悬赏投诉有答案未采纳为最佳
发表于 2011-3-26 10:02:41 | 显示全部楼层   陕西省汉中市
#include <iostream>
using namespace std;
int main()
{
        int a,b,c,d;
        cout <<"请输入一个整数,回车键确定:"<<endl;
        cin >>a;
        cout <<"运算方法有:"<<endl;
        for ( b=0;b<a;b)
        {
          ++b;
          if (b<=1){
                  cout <<a<<"="<<"1"<<"*"<<a<<endl;
          }
          else {
                for (c=0;c<a;c)
                {
                        ++c;
                        if (b*c==a) {
                                cout <<a<<"="<<b<<"*"<<c<<endl;
                        }
                        else {
                           for (d=0;d<a;d)
                        {
                                ++d;
                                if (b*c*d==a) {
                                        cout <<a<<"="<<b<<"*"<<c<<"*"<<d<<endl;
                                }
                           }
                }
        }
          }
        }
        return 0;
}

又看了一下,觉得这个和你的要求比较接近,
说实话我都觉得代码写的不好,
哎,新手嘛,请谅解.....
QQ截图未命名.gif
回复

使用道具 举报

结帖率:65% (13/20)
发表于 2011-3-26 10:16:29 | 显示全部楼层   山东省济南市
不懂这个,等高手
回复

使用道具 举报

发表于 2011-3-26 10:36:05 | 显示全部楼层   山东省潍坊市
很简单的东西吧。。记得初中做这个 不过使用 个。。什么编写的来 忘记了
回复

使用道具 举报

发表于 2011-4-23 13:13:24 | 显示全部楼层   陕西省汉中市
#include <iostream>
using namespace std;
int main()
{
        int a;
        cout <<"请输入一个整数,回车键结束."<<endl;
        cin >>a;
        for (int b=0;b<a;b)
        {
                ++b;
                for (int c=0;b*c<=a;c++)
                {
                        if (b*c==a){
                                cout <<a<<"="<<b<<"*"<<c<<endl;
                        }
                }

        }

                return 0;
}


我也是初学,所以这段代码只能判断两个相成的数
如:  12=1*12
       12=2*6
        12=3*4
        12=4*3
        12=6*2
        12=12*1
新手代码写的很不好,见笑了....
回复

使用道具 举报

结帖率:40% (4/10)
发表于 2011-4-23 19:42:55 | 显示全部楼层   广东省深圳市
哇塞~  全部英文、  看不懂~
回复

使用道具 举报

结帖率:100% (2/2)

签到天数: 1 天

发表于 2011-4-23 21:34:38 | 显示全部楼层   浙江省温州市
简单吗?不觉得。。
回复

使用道具 举报

结帖率:33% (13/40)
发表于 2011-4-24 00:02:33 | 显示全部楼层   广西壮族自治区贵港市
本帖最后由 qq605608886 于 2011-4-24 00:06 编辑

遍历咯

变量循环首(0,20,1,A)      '不知道有多少解法  ,就 20种,从里面找出正确的解法

  如果真(A<>0 )   ' 1就为自身 ,所以驱除
     变量循环首(0,20,1,I)       '不知道有多少解法  ,就 20种,从里面找出正确的解法

                    B=A*I                        '从2开始,从1就是本身了
               如果真(A=某个数字)
                              C.倍数=A     '从首个循环开始的已经循环次数,也就是倍数
                             C.乘数=I
                               加入成员(正确解法,C)
                       如果真(B>指定解法数字)    '超出解法的指定数字
                            跳出循环
      变量循环尾()

变量循环尾()
回复

使用道具 举报

结帖率:33% (13/40)
发表于 2011-4-24 00:03:38 | 显示全部楼层   广西壮族自治区贵港市
本帖最后由 qq605608886 于 2011-4-24 00:04 编辑

最后从数组1个1个导出   ,就知道  倍数和乘数了

要想知道有多少种解法.取数组成员数()  就可以了
回复

使用道具 举报

结帖率:33% (1/3)
发表于 2011-7-3 16:37:23 | 显示全部楼层   山东省淄博市
591173144 发表于 2011-3-26 10:02
#include
using namespace std;
int main()

好,精辟啊!!
回复

使用道具 举报

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

本版积分规则 致发广告者

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

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

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