码迷,mamicode.com
首页 > 其他好文 > 详细

poj3370 鸽笼原理

时间:2014-11-24 22:37:11      阅读:188      评论:0      收藏:0      [点我收藏+]

标签:poj3370

题意:首先输入c n,接着是n个数,问你有没有k个数(1<=k<=n),使得其和能整除c

           输出其对应下标,只输出一组符合条件的就行;

分析:http://blog.csdn.net/bigsungod/article/details/41450729

代码:

#include <queue>
#include <stack>
#include <math.h>
#include <vector>
#include <limits.h>
#include <stdio.h>
#include <iostream>
#include <string.h>
#include <algorithm>
#include <functional>
#define N 100010
#define LL long long
#define mem(a) memset(a,0,sizeof(a));
#define mem_1(a) memset(a,-1,sizeof(a));
using namespace std;
int n,c;
int f[N];
int sum[N];
int pos[N];
void work()
{
    int j;
    memset(pos, -1, sizeof(pos));
    pos[0] = 0;
    for (int i = 1; i <= n; i++)
        if (pos[sum[i]] == -1)
            pos[sum[i]] = i;
        else
        {
            for ( j = pos[sum[i]] + 1; j < i; j++)
                printf("%d ", j);
            printf("%d\n", j);
            return;
        }
}
int main()
{
    while(scanf("%d%d", &c,&n)){
            if(c==0&&n==0)
            break;
    for (int i = 1; i <= n; i++)
        scanf("%d", &f[i]);
    sum[0] = f[0] = 0;
    for (int i = 1; i <= n; i++)
        sum[i] = (sum[i - 1] + f[i]) % c;
    work();
    }
    return 0;
}


poj3370 鸽笼原理

标签:poj3370

原文地址:http://blog.csdn.net/bigsungod/article/details/41452989

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!