CSDN挑战编程——《数学问题》
数学问题
题目详情:
给你两个长度为n的正整数序列分别为{a1,a2,a3...an},{b1,b2,b3...bn},0<ai,bi<=100;
设S=max{x1*a1+x2*a2+x3*a3+...+xn*an,(1-x1)*b1+(1-x2)*b2+(1-x3)*b3+...+(1-xn)*bn},xi为整数。0<=xi<=1。
请你求出S的最小值。
输入描写叙述:
输入包括多组測试数据。以文件结尾。
每组測试数据包括三行行,第一行为一个正整数n(0<n<=100);第二行输入的是ai,第三行输入的是bi,每两个数以空格隔开。
输出描写叙述:
对于每组測试数据输出对应的答案。
答题说明:
输入例子:
3
2 9 4
2 1 8
3
1 2 3
2 1 1
输出例子:
4
2
/*
思路:
a[],b[]数组中相应坐标位置的数据不同则取最小的那个(取到相应的count1,count2中去)。
同样的数据(存到c[]数组中)待后面动态规划分组。 动态规划的根据是,分两组的差值和 count1与count2的差值最接近然后求结果。
*/
#include "stdio.h"
#include "stdlib.h"
#define maxn 100+10 int a[maxn],count1,b[maxn],count2,n;
int c[maxn],len; inline double abs(double x)
{
return x>0?x:-1*x;
} int fun(int size)
{
int index;
double s1,tmp;
int *buf=(int *)malloc(sizeof(int)*size);
s1=(size-count2+count1)/2.0; //最佳分组中最小一组的和,去与s1最接近的值
buf[0]=0; index=1; tmp=buf[0];
for(int i=1;i<=size;i++){
buf[i]=0; buf[i]=buf[i-1];
for(int j=0;j<len;j++){
if(i-c[j]>=0 && buf[i]<c[j]+buf[i-c[j]]){
buf[i]=c[j]+buf[i-c[j]];
}
} if(abs(s1-buf[i])<=abs(s1-tmp)){
tmp=buf[i];
index=i;
}else{
break;
}
// printf("%d ",buf[i]);
} return (count2+buf[index])>(count1+size-buf[index])?(count2+buf[index]):(count1+size-buf[index]);
} int main()
{ while(scanf("%d",&n) && n>0)
{
int i,sum;
for(i=0;i<n;i++){
scanf("%d",&a[i]);
} for(i=0,len=0,count1=0,count2=0,sum=0;i<n;i++){
scanf("%d",&b[i]);
if(a[i]<b[i]){
count1+=a[i];
}else if(a[i]>b[i]){
count2+=b[i];
}else{
c[len++]=a[i];
sum+=a[i];
}
} if(count1>count2){
int tmp=count2; count2=count1; count1=tmp;
} if(len>0){
printf("%d\n",fun(sum));
}else{
printf("%d\n",count1>count2?count1:count2);
} }
}
本人愚昧。代码不优,超时的说,拿出来衬托一下大神同一时候希望大神们给些改良意见。感谢
CSDN挑战编程交流群:372863405
CSDN挑战编程——《数学问题》的更多相关文章
- CSDN挑战编程——《绝对值最小》
绝对值最小 题目详情: 给你一个数组A[n],请你计算出ans=min(|A[i]+A[j]|)(0<=i,j<n). 比如:A={1, 4, -3}, 则: |A[0] + A[0]| ...
- CSDN挑战编程——《金色十月线上编程比赛第二题:解密》
金色十月线上编程比赛第二题:解密 题目详情: 小强是一名学生, 同一时候他也是一个黑客. 考试结束后不久.他吃惊的发现自己的高等数学科目竟然挂了,于是他果断入侵了学校教务部站点. 在入侵的过程中.他发 ...
- (Step1-500题)UVaOJ+算法竞赛入门经典+挑战编程+USACO
http://www.cnblogs.com/sxiszero/p/3618737.html 下面给出的题目共计560道,去掉重复的也有近500题,作为ACMer Training Step1,用1年 ...
- 算法竞赛入门经典+挑战编程+USACO
下面给出的题目共计560道,去掉重复的也有近500题,作为ACMer Training Step1,用1年到1年半年时间完成.打牢基础,厚积薄发. 一.UVaOJ http://uva.onlinej ...
- csdn在线编程里面的一个排列组合题
是csdn在线编程里面的一个问题 回文字符串是指从左到右和从右到左相同的字符串,现给定一个仅由小写字母组成的字符串,你可以把它的字母重新排列,以形成不同的回文字符串. 输入:非空仅由小写字母组成的字符 ...
- C语言:输入10个整数,找出其中绝对值最小的数
1 输入10个整数,找出其中绝对值最小的数(10分) 题目描述 输入10个整数,找出其中绝对值最小的数 输入 十个整数 输出 绝对值最小的数 样例输入 -10 -2 30 40 50 60 70 80 ...
- 挑战编程 uva100 3n+1
挑战编程 刘汝佳 的第一道习题 热身题 熟悉下提交格式 题意 #include <iostream> #include <algorithm> using namespace ...
- TZOJ 4024 游戏人生之梦幻西游(连续子段和绝对值最小)
塔神酷爱玩梦幻西游这款游戏,这款游戏以著名的章回小说<西游记>故事为背景,透过Q版的人物,营造出浪漫的网络游戏风格.塔神以追求天下无敌为目标,从一个默默无闻的菜鸟,打拼到了登峰造极的大师, ...
- 编程算法 - 最小的k个数 红黑树 代码(C++)
最小的k个数 红黑树 代码(C++) 本文地址: http://blog.csdn.net/caroline_wendy 题目: 输入n个整数, 找出当中的最小k个数. 使用红黑树(multiset) ...
随机推荐
- REST和SOAP Web Service的比较
1.http://stevenjohn.iteye.com/blog/1442776 2.http://blog.csdn.net/cnyyx/article/details/7483766
- jrae源码解析(二)
本文细述上文引出的RAECost和SoftmaxCost两个类. SoftmaxCost 我们已经知道,SoftmaxCost类在给定features和label的情况下(超参数给定),衡量给定权重( ...
- ADO.NET复习——自己编写SqlHelper类
今天复习了一次ADO.NET基础,整理一下自己的认为的重点: 编写SqlHelper类,方便我们执行数据库语句,这时可以直接调用封装在SqlHelper类的方法.现在大多数公司面试的时候,给你的面试题 ...
- 爬虫爬oj用户头像
import requests import Queue import urllib import urllib2 import re import requests alreadyImg = set ...
- js学习笔记之:时间(三)
今天来学习一个简单的时间应用:时间的倒影,如图所示: 主要知识点: 1 获取系统的时间值:2 建立一个div的倒影 div的倒影主要利用css来控制,函数值为:filter:flipv() 步骤 ...
- Destoon QQ互联一键登录审核不通过的解决方案
在QQ互联上申请帐号之后提交了审核, 后台填写APPID和KEY之后自己申请的QQ号可以正常登录,但QQ互联审核的时候一直审核不通过说是“您的网站审核未通过,原因是“点击QQ登录按钮提示登录失败或出现 ...
- mysql存储过程的权限 definer
mysql中用户对存储过程的权限有: ALTER ROUTINE 编辑或删除存储过程 CREATE ROUTINE 创建存储过程 EXECUTE运行存储过程 存储过程的创建者拥有存储过程的ALTER. ...
- C语言基础学习运算符-赋值运算符
简单赋值 在C语言里,运算符=并不表示相等,而是一个赋值运算符.这意味着,符号=的左边该是一个可修改的变量名,而右边是赋给该变量的值. 如下程序语句: i = i+; 在数学上,该等式无法成立.而作为 ...
- Python3 如何优雅地使用正则表达式(详解一)
注:本文翻译自 Regular Expression HOWTO,小甲鱼童鞋对此做了一些注释和修改. 正则表达式介绍 正则表达式(Regular expressions 也称为 REs,或 regex ...
- python里的Join函数
用法是将数组里的每个元素用字符连接起来 import string string.join(["aaaa", "bbb"]) 或者: from string i ...