鱼C论坛

 找回密码
 立即注册
查看: 3020|回复: 6

选举问题,速速戳进来

[复制链接]
发表于 2014-4-5 22:08:01 | 显示全部楼层 |阅读模式
20鱼币
选举问题
题目详情:
在许多选举的问题上,并不是每个人都是一张票的,很多时候会由于每个人的权利不同导致每个人的话事权也不一样(可认为所拥有的票数)假设有选举人V1,V2...Vk,他们所拥有的票数分别为w1,w2...wk;并设优势联盟为所有选举人的一个子集且他们的总票数超过一半。而Vi拥有的权利指数为在有他的所有优势联盟中,他退出便能使优势联盟变为劣势联盟的次数。若Vi一个人的票数便已经超过一半,则称他为独裁者,我们认为这种选举是不公平的。现在,我们就是要看一个选举系统是否存在独裁,若不存在,求出每个选举人的权利指数。

输入:第一行为T,表示有T个案例!每个案例第一行为k,表示有k个选举人(1<k<=20),第二行为k个数,表示每个选举人所拥有的票数。

输出:若存在独裁,则输出"It's unfair!",否则输出每个选举人的权利指数。







答题说明:
输入案例:

2

2

5 1

5

3 4 5 6 7

输出案例:

It's unfair!

4 4 4 8 8
求问题代码。,,,O(∩_∩)O谢谢

最佳答案

查看完整内容

写了下,感觉算法不是很好,你可以修改下
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2014-4-5 22:08:02 | 显示全部楼层
本帖最后由 似水无痕 于 2014-4-7 18:05 编辑

写了下,感觉算法不是很好,你可以修改下
  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. int election(int start, int end, int *ballot, int *sum);
  4. int comparator(const void *, const void *);
  5. //void qsort ( void * base, size_t num, size_t size, int ( * comparator ) ( const void *, const void * ) );

  6. int main()
  7. {
  8.         int ballot[20];
  9.         int sum[1024 * 1024];
  10.         
  11.         int index;
  12.         int t, k, i, j, p;
  13.         int allsum;
  14.         int rangeless, rangeabove;
  15.         int temp, num1, num2, pow;
  16.         double halfsum;
  17.                
  18.         scanf("%d", &t);
  19.         
  20.         for(i = 0; i < t; i++) {
  21.                 scanf("%d", &k);
  22.                 for(j = 0, allsum = 0; j < k; j++) {
  23.                         scanf("%d", ballot + j);
  24.                         allsum += ballot[j];
  25.                 }
  26.                 halfsum = allsum / 2.0;
  27.                 //判断是否有独裁
  28.                 for(j = 0; j < k; j++) {
  29.                         if(ballot[j] > halfsum) break;
  30.                 }
  31.                 if(j != k) {
  32.                         printf("It's unfair!\n");
  33.                         continue;
  34.                 }
  35.                 //计算权数
  36.                 for(j = 0; j < k; j++) {
  37.                         rangeless = halfsum - ballot[j] + 1;
  38.                         rangeabove = (halfsum - (int)halfsum)*2 + (int)halfsum - 1;
  39.                         temp = ballot[j];
  40.                         ballot[j] = ballot[k - 1];
  41.                         
  42.                         index = election(0, k-2, ballot, sum);
  43.                         qsort(sum, index, sizeof(int), comparator);
  44.                         //printf("\n%d %d\n", rangeless, rangeabove);
  45.                         /*for(p = 0; p < index; p++) {
  46.                                 printf("%d ", sum[p]);
  47.                         }*/
  48.                         
  49.                         num1 = binfind(sum, index, rangeless);
  50.                         //printf("\n%d\n", num1);
  51.                         if(sum[num1] < rangeless) {
  52.                                 while(sum[num1++] < rangeless && num1 < index);
  53.                                 num1--;
  54.                         } else {
  55.                                 while(sum[num1--] >= rangeless && num1 >= 0);
  56.                                 num1 = (num1 == -1) ? 0 : num1+2;
  57.                         }
  58.                         
  59.                         num2 = binfind(sum, index, rangeabove);
  60.                         if(sum[num2] <= rangeabove) {
  61.                                 while(sum[num2++] <= rangeabove && num1 < index);
  62.                                 num2 = (num2 == index) ? num2-1 : num2-2;
  63.                         } else {
  64.                                 while(sum[num2--] > rangeabove && num2 >=0);
  65.                                 num2++;
  66.                         }
  67.                         //printf("\n%d %d\n", num2, num1);
  68.                         printf("%d ", num2 - num1 +1);
  69.                         
  70.                         ballot[j] = temp;
  71.                         
  72.                 }
  73.                 printf("\n");
  74.         }
  75.         
  76.         return 0;
  77.         
  78. }

  79. int election(int start, int end, int *ballot, int *sum)
  80. {
  81.         int index; // 下一个要写的数的位置
  82.         if(start == end) {
  83.                 sum[0] = 0;
  84.                 sum[1] = ballot[end];
  85.                 index = 2;
  86.                 return index;
  87.         }
  88.         
  89.         //start++;
  90.         index = election(start+1, end, ballot, sum);
  91.         
  92.         int i;
  93.         for(i = 0; i < index; i++) {
  94.                 sum[index + i] = sum[i] + ballot[start];
  95.         }
  96.         return index * 2;

  97. }

  98. int comparator(const void *a, const void *b)
  99. {
  100.         if(*(int *)a < *(int *)b)
  101.                 return -1;
  102.         else if(*(int *)a == *(int *)b)
  103.                 return 0;
  104.         else
  105.                 return 1;
  106.                         
  107. }

  108. int binfind(int val[] , int num , int value)
  109. {
  110.         int start = 0;
  111.         int end = num - 1;
  112.         int mid = (start + end)/2;
  113.         while(val[mid] != value && start < end) {
  114.                 if (val[mid] > value) {
  115.                         end = mid - 1;
  116.                 } else if (val[mid] < value) {
  117.                         start = mid + 1;
  118.                 }
  119.                 mid = ( start + end )/2;
  120.         }
  121.         return mid;
  122. }
复制代码


小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2014-4-9 18:50:22 | 显示全部楼层

回复晚了,抱歉啊,你这个方法确实可以,不过代码太长了,运行的话直接属于超时,不过还是谢谢了,不知道能更简洁点不
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2014-4-9 22:28:13 | 显示全部楼层
你是在做acm,自己暂时还没想到什么更有效的算法:cry
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2014-4-10 22:48:52 | 显示全部楼层
新鱼友一个,不能添加好友:cry
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2014-4-12 17:23:09 | 显示全部楼层
似水无痕 发表于 2014-4-10 22:48
新鱼友一个,不能添加好友

没事,能写出这个问题的程序,咱都一样啦
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2014-6-13 01:29:49 | 显示全部楼层
楼主  可以把你的代码过来看看吗????我写的没过
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-10 05:03

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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