zoj 2042 - Divisibility

题目:给你一串数字,不改变数字的顺序而在他们之间加入减号或者加号,问结能否整除m。

分析:dp,背包类似物。容量为0 ~ m-1。

状态:f(i,j)为前i个数组合结果的余数为j的真值;

转移:f(i,j)= max(f(i-1,j-a[i]),f(i-1),j+a[i]){ 结果对应值在0 ~ m-1之间  };

说明:(2011-9-19 11:24)。

#include <iostream>
#include <cstdlib>
#include <cstring>
#include <stdio.h>

using namespace std;

bool F[ 10003 ][ 103 ];
int  N[ 10003 ];

int main()
{
    int t,n,k;
    while ( scanf("%d",&t) != EOF )
    while ( t -- ) {
        scanf("%d%d",&n,&k);
        for ( int i = 0 ; i < n ; ++ i )
            scanf("%d",&N[ i ]); 

        for ( int i = 0 ; i < n ; ++ i )
            N[ i ] = (k+N[ i ]%k)%k;

        memset( F, false, sizeof( F ) );
        F[ 0 ][ N[ 0 ] ] = true;

        for ( int i = 1 ; i < n ; ++ i )
        for ( int j = 0 ; j < k ; ++ j )
            if ( F[ i-1 ][ j ] ) {
                F[ i ][ (k+j-N[ i ])%k ] = true;
                F[ i ][ (k+j+N[ i ])%k ] = true;
            }

        if ( F[ n-1 ][ 0 ] )
            printf("Divisible\n");
        else
            printf("Not divisible\n");
        if ( t ) printf("\n");
    }
    return 0;
}
时间: 2024-10-21 08:15:09

zoj 2042 - Divisibility的相关文章

图论 500题——主要为hdu/poj/zoj

转自——http://blog.csdn.net/qwe20060514/article/details/8112550 =============================以下是最小生成树+并查集======================================[HDU]1213   How Many Tables   基础并查集★1272   小希的迷宫   基础并查集★1325&&poj1308  Is It A Tree?   基础并查集★1856   More i

HDU 3335 Divisibility(DLX可重复覆盖)

Problem Description As we know,the fzu AekdyCoin is famous of math,especially in the field of number theory.So,many people call him "the descendant of Chen Jingrun",which brings him a good reputation. AekdyCoin also plays an important role in th

概率dp ZOJ 3640

Help Me Escape Time Limit:2000MS     Memory Limit:32768KB     64bit IO Format:%lld & %llu Submit Status Practice ZOJ 3640 Appoint description:  System Crawler  (2014-10-22) Description Background     If thou doest well, shalt thou not be accepted? an

zoj 2156 - Charlie&#39;s Change

题目:钱数拼凑,面值为1,5,10,25,求组成n面值的最大钱币数. 分析:dp,01背包.需要进行二进制拆分,否则TLE,利用数组记录每种硬币的个数,方便更新. 写了一个 多重背包的 O(NV)反而没有拆分快.囧,最后利用了状态压缩优化 90ms: 把 1 cents 的最后处理,其他都除以5,状态就少了5倍了. 说明:貌似我的比大黄的快.(2011-09-26 12:49). #include <stdio.h> #include <stdlib.h> #include <

ZOJ 1718 POJ 2031 Building a Space Station 修建空间站 最小生成树 Kruskal算法

题目链接:ZOJ 1718 POJ 2031 Building a Space Station 修建空间站 Building a Space Station Time Limit: 2 Seconds      Memory Limit: 65536 KB You are a member of the space station engineering team, and are assigned a task in the construction process of the statio

ZOJ 3607 Lazier Salesgirl (贪心)

Lazier Salesgirl Time Limit: 2 Seconds      Memory Limit: 65536 KB Kochiya Sanae is a lazy girl who makes and sells bread. She is an expert at bread making and selling. She can sell the i-th customer a piece of bread for price pi. But she is so lazy

ZOJ - 2243 - Binary Search Heap Construction

先上题目: Binary Search Heap Construction Time Limit: 5 Seconds      Memory Limit: 32768 KB Read the statement of problem G for the definitions concerning trees. In the following we define the basic terminology of heaps. A heap is a tree whose internal n

ZOJ 2859 二维线段树

思路:自己写的第二发二维线段树1A,哈哈,看来对二维的push操作比较了解了:但是还没遇到在两个线段树中同时进行push操作的,其实这题我是想在x维和y维同时进行push操作的,但是想了好久不会,然后看到这题又给出10秒,然后想想在x维线段直接单点查询肯定也过了,然后在第二维就只有pushup操作,在第一维线段树没有pushup操作.要是在第一维也有pushup操作的话,那就不用单点查询那么慢了.不过也A了,想找题即在二维同时进行pushup和pushdown操作的. #include<iost

ZOJ 2588

求一个无向图的桥(可能存在重边),输出割边的数目,并按顺序输出割边的序号(输入的顺序). 由于内存的限制 , 无法使用邻接矩阵 , 只能用邻接表了 . 第一次用了邻接表,超内存了: 1 #include <iostream> 2 #include <cstdio> 3 #include <algorithm> 4 #include <string.h> 5 using namespace std; 6 const int N=10002; 7 const i