PATA1086

来源:互联网 发布:加拿大 软件 研究生 编辑:程序博客网 时间:2024/06/07 07:09

OS: OS X 10.10.5
IDE:Xcode 7.2.1

#include <stdio.h>#include <stdlib.h>#include<time.h>int cmp ( const void *a , const void *b){//a function used in the qsort    return *(int *)b - *(int *)a; //decreasing order.}int main(int argc, const char * argv[]) {    int N,M;    scanf("%d%d",&N,&M);    int MaxSum[N+1][M+1];//MaxSum[i][j] represents the maximal sum of the preceding i numbers, and the sum is <=j    int flag[N+1][M+1];// flag[i][j]==1  represents  Number[i] is number to be added to get MaxSum[i][j], while flag[i][j]==0 not    for (int i=0; i<=N; i++) { //initilaize MaxSum[][] and flag[][]        for (int j=0; j<=M; j++) {            MaxSum[i][j]=0;            flag[i][j]=0;        }    }    int Number[N];    for (int i=1; i<=N; i++) { //read N numbers        scanf("%d",&Number[i]);    }    /*for(int i=1;i<n;i++){ //to test large nunbers of data, assign the Number[i] from 1 to n,     Number[i]=1;//because the Number[i] will be sorted ,so the sequence is not important.     }*/    qsort(&Number[1],N ,sizeof(int),cmp); //sort in the sequence of decreasing    for (int i=1; i<=N; i++) {//loop        for (int j=1; j<=M; j++) {            if (j-Number[i]<0||MaxSum[i-1][j-Number[i]]+Number[i]<MaxSum[i-1][j]) {// Number[i] is not  number to be added to get MaxSum[i][j]                MaxSum[i][j]=MaxSum[i-1][j];            }            else{// Number[i] is number to be added to get MaxSum[i][j]                MaxSum[i][j]=MaxSum[i-1][j-Number[i]]+Number[i]; //calculate MaxSum[i][j]                flag[i][j]=1; //label it to track trail            }        }    }    int Sum=0;//test whether the result is true or not    if (MaxSum[N][M]!=M) { //MaxSum[N][M] < M, that is ,no solution        printf("No Solution");//print    }    else{        int flag2=0;//for the format of outputing        for (int i=N,j=M; j>0; i--) { //because all the number is in decreasing order,so we print the numbers in increasing order,            if (!flag[i][j]) { //flag[i][j] check whether Number[i] is number to be added to get MaxSum[i][j] or not                flag[i][j]=1; //label it.                continue;//next loop            }            if (!flag2++) {                printf("%d",Number[i]);//priint the first number                Sum+=Number[i];            }            else{                printf(" %d",Number[i]);//print the next number                Sum+=Number[i];            }            j-=Number[i];//subtract from sum.        }    }    /*printf("\n");    if (Sum==M) {        printf("The result is true.\n");    }    else{        printf("The result is false.\n");    }*/    return 0;}
1 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 父母看孩子总是吵架怎么办 20岁父母离婚我怎么办 碰到没素质的人怎么办 父母抛弃了我该怎么办 父母说家里没钱困难怎么办 遇到素质低的老婆怎么办 孩子考试心里素质差怎么办 5岁儿童脾气不好怎么办 有一个素质差的父母怎么办 孩子对什么都无所谓怎么办 孩子在学习上无所谓怎么办 孩子对学习无所谓的态度怎么办 孩子不上进什么都无所谓怎么办 倔强的学生不理老师怎么办 一岁宝宝特别犟怎么办 孩子遇到问题喜欢发脾气怎么办 企业培养新人跑了怎么办 二年级学生读不懂题目怎么办 6岁宝宝有鼻炎怎么办 外地儿童怎么办北京医保卡 江苏联宝投资的钱怎么办 银行叫开了证券怎么办 中班心理健康我不开心了怎么办 大学生心理健康课总是抢不到怎么办 孩子成绩提不上去怎么办 孩子数学不开窍怎么办 二年级 初中孩子语文不开窍怎么办 分到的班级都是差生怎么办 初三了英语差怎么办呀 初三了英语差的很怎么办 五年级英语太差怎么办 听课效率没有自学效率高怎么办 小学生不好好写作业怎么办 带的家教成绩没有提高怎么办 学生出国学校成绩证明怎么办 学生成绩考差了班主任怎么办 高一的学生成绩跟不上怎么办 综合素质评价手册丢了怎么办 小学综合素质评价手册丢了怎么办 人体质不出汗差怎么办 儿子一年级语文成绩太差怎么办