求C语言算法比如输入15,要求在1,2,3,4,5.20里面求任任意数想加等于15,且得出的结果是按相加数数量从少到多排列,比如两位数相加排第一,三位数相加排第二.等,其中相加数1,2,3,4,5.20不变,每次就

来源:学生作业学帮网 编辑:学帮网 时间:2024/05/05 02:59:52

求C语言算法
比如输入15,要求在1,2,3,4,5.20里面求任任意数想加等于15,且得出的结果是按相加数数量从少到多排列,比如两位数相加排第一,三位数相加排第二.等,其中相加数1,2,3,4,5.20不变,每次就是输入计算数(15).能否用最简单的C语言算法完成,我是初学者.

// 这种算法我会这样做,虽不是最优算法,但起码能解决问题,具体完整算法如下:
#include "stdafx.h"
#include <stdio.h>
#include <stdlib.h>


#define  ARR_MAX 20
#define TARGET_MAX 19
inline void print_result(const int a[],const int t[],int m,int calValue){
\x09int sum,i;
\x09i=sum=0;

\x09for(i=0;i<m;i++){ 
\x09\x09sum+=a[t[i]];
\x09}

\x09if(sum==calValue){
\x09\x09for(i=0;i<m;i++) printf("%d+",a[t[i]]);
\x09\x09printf("\b=%d\n",calValue);
\x09}
}

bool Com(int a[],int n,int m,int calValue){
\x09if(m>n) return false;
\x09int temp[TARGET_MAX];
\x09int i,k;
\x09i=k=0;

\x09for(i=0;i<m;i++) temp[i]=-1;

\x09temp[k]=0;
\x09while (true){
\x09\x09if (temp[k]>=n){
\x09\x09\x09if(k==0) break;
\x09\x09\x09--k;
\x09\x09\x09temp[k]+=1;
\x09\x09}else if(k==m-1){
\x09\x09\x09print_result(a,temp,m,calValue);
\x09\x09\x09temp[k]+=1;
\x09\x09}else{
\x09\x09\x09++k;
\x09\x09\x09temp[k]=temp[k-1]+1;
\x09\x09}
\x09}
\x09return true;
}
int _tmain(int argc, _TCHAR* argv[])
{
\x09
\x09int a[ARR_MAX];
\x09int i,calValue;
\x09for(i=1;i<=ARR_MAX;i++) a[i-1]=i; // 为数组分配初始值 即1~20
\x09
\x09printf("请输入要计算的值:");
\x09scanf("%d",&calValue);
\x09
\x09if(calValue==210){
\x09\x09printf("1+2+...+20=%d\n",calValue);
\x09\x09return 1;
\x09}
\x09else if(calValue>210||calValue<=0){
\x09\x09printf("不在计算范围内,请重试.\n");
\x09\x09return 1;
\x09}
\x09for (i = 2; i <=TARGET_MAX; i++)
\x09{   // 开始调用函数
\x09\x09Com(a,ARR_MAX,i,calValue);
\x09}
\x09
\x09system("pause");
\x09return 0;
}

求C语言算法比如输入15,要求在1,2,3,4,5.20里面求任任意数想加等于15,且得出的结果是按相加数数量从少到多排列,比如两位数相加排第一,三位数相加排第二.等,其中相加数1,2,3,4,5.20不变,每次就 求c语言2个数最大公约数和最小公倍数的算法不要求写程序 只要算法 C语言数字全排列的问题(急!)求C代码和算法【问题描述】输入整数N( 1 C语言 输入20个整数,要求1:打印所有负数.要求2:输出正数之和 C语言 设计算法输入一个四位正整数,将它们倒排,例如输入1234,输出4321.设计算法输入一个四位正整数,将它们倒排,例如输入1234,输出4321.(提示:分别应用/ 求整数部分,%求余数部分.例如7/5=1,7%5=2 c语言的程序 对实数进行四则运算的程序 要求计算顺序,先乘除,后加减,优先括号c语言的程序,做一个可以对实数进行四则运算的c语言的程序 比如输入1+2回车显示3,输入1+2*3回车显示7 输入(2.1+3 C语言归并排序算法实现和比较!2、设计内容及要求:内容:实现两路归并排序和三路归并排序算法,并比较各种算法的比较次数和移动次数.² 要求:(1) 输入不少于10个元素的无序、正序 这道c语言的问题求算法.若能给段有详解的程序那就太感谢了.找倍数 时限:1000ms 内存限制:10000K 总时限:3000ms 描述:  对于每个输入的数字(如:2),则要求 给出一个由1,0构成的十进制 求C语言的从1-55的矩阵排列组合算法要求写出完整的代码.行列都是6 求C语言答案 1,输出一个3位整数的逆序数,比如输入123,输出321 2,计算球的体积和表面积 C语言如何实现输入10个整数,每行6个整数奇偶比例3:3输入比如输入1,2,3...10实现 C语言实现的矩阵加减乘法要求:1、用到指针;2、矩阵以数组的形式输入,结果以矩阵的形式输出.比如:输入一个2*3的矩阵,可以输入:1 2 3 4 5 6然后输出形式要求是这种形式:1 2 3 4 5 6就是以 求C语言算法2的N次方,N 用C语言描述下列算法,并给出算法的时间复杂度.(1)求一个n阶方阵的所有元素之和.(2)对于输入的任意三个整数,将它们按从小到大的顺序输出.(3)对于输入的任意n个整数,输出其中的最 C语言编程中,求两个数的最大公约数和最小公倍数算法是怎样的输入两个正整数m n求最大公约数和最小公倍数(解释一下算法)谢谢 用C语言实现微积分计算要求:1,算法解释和介绍.2,提供正确的可执行代码 编一个简单的C语言小程序.关于RSA算法的其实是关于RSA加密算法的内容,具体你就不用管它啦……功能是这样的,1、首先要求输入三个数字,n,e,d.2、然后给出选择,一:加密;输入明文x,则输出秘 C语言中输入1 2 C语言中输入 1 2 3