`
zhouzhao21
  • 浏览: 72676 次
  • 性别: Icon_minigender_1
  • 来自: 合肥
社区版块
存档分类
最新评论

网上没找到答案的逻辑推理题

阅读更多
今天去一家游戏公司面试,这一题没推出来。在网上也没找到合理的答案。只能劳烦大家了。请大家不要用穷举法,如果知道答案请将推理过程写出来。谢了。

甲、乙、丙三队互相比赛,每两队之间都比赛了同样多的场数,然后根据得分的多少,决定哪一队是最后的胜利者。规则是每场比赛,胜者得3分,负者得0分,平局各得1分。

甲队在全部比赛结束之后,得意洋洋的说:“我们队赢的场数比你们两队中的任何一队都多。”

乙队反唇相击,道:“我们队输的场数比你们两队中的任何一队都少。”

唯有丙队发言人一声不吭。

你认为丙队会排名第一吗?

注意:甲、乙、丙三队,每两队之间的比赛场数可以不止一场。 甲、乙、丙三队互相比赛,每两队之间都比赛了同样多的场数,然后根据得分的多少,决定哪一队是最后的胜利者。规则是每场比赛,胜者得3分,负者得0分,平局各得1分。

甲队在全部比赛结束之后,得意洋洋的说:“我们队赢的场数比你们两队中的任何一队都多。”

乙队反唇相击,道:“我们队输的场数比你们两队中的任何一队都少。”

唯有丙队发言人一声不吭。

你认为丙队会排名第一吗?

注意:甲、乙、丙三队,每两队之间的比赛场数可以不止一场。
分享到:
评论
35 楼 jnoee 2009-09-15  
标准答案其实是这样的:
甲乙两队打平,所以一个“得意洋洋”一个“反唇相讥”。
丙队是垫底的,所以丙队发言“一声不吭”。
34 楼 monsterjiao 2009-09-15  
bookong 写道
monsterjiao 写道
如果喜欢足球比赛并关注得的话,心算一下应该就能出来吧:
一个简单的例子就能证明丙有夺冠的可能:
队伍  胜   负   平    总积分
甲    3    5   0      9
乙    1    1   6      8  
丙    2    2   4      10
此题解法:
先证明丙会超过乙的积分:乙比并少输,但是输球是0分,而胜是3分,平是1分,那么丙只要将比乙多输的一场放到胜场上,也就是说丙比乙多赢也多输了一场,而平局自然就是乙比丙多了两场,算下来3-2=1,丙超过了乙的积分。
然后证明丙会超过甲的积分:甲比丙多赢一场,光看胜场是多了3分,而甲比并多输的场是可以无限多加入为N吧(反正题目中又没有说三队之前是进行了多少场比较),那么丙的平局的场次自然就比甲多出N-1,(N-1)*1>3的情况很容易出现吧。
希望能帮助到你


对不起,我真没看懂你的例子,我有两个疑问:
1、看看乙吧,1×3+6在什么情况下能等于8?
2、甲负了5场,乙和丙胜利加起来1+2=3,那两场是跟谁?


嘿嘿,不好意思;是我的问题;当时重在解题思路了,再说也是思路不够缜密,例子举错了~但也只是错例子而已;谢谢指出。
33 楼 q472732639 2009-09-13  
啊lei lei!..审题没审明白..
32 楼 q472732639 2009-09-13  
/**
 * 
 * @author q472732639
 *
 */
public class Test {

	public static void main(String [] args){
		TeamObj a = new TeamObj();		//A队
		TeamObj b = new TeamObj();		//B队
		TeamObj c = new TeamObj();		//C队
		int roundNum = 1;	//回合数
		/*
		 * 下面的纯粹就是按照题意所写的判断 不精湛 粗略的理解为a是必须赢数多.但不一定不输,
		 * b必须是输数少,但不一定去赢,c是积分一定要高,但一定要让A,B两组积分低的情况下不影响战绩..全是废话
		*/
		for(int i = 0 ; i < roundNum ; i ++){
			if(a.getWinNum() <= b.getWinNum() 
					|| a.getWinNum() <= c.getWinNum()){
				a.setWinNum(a.getWinNum() + 1);
				a.setMin(a.getMin() + 2);
				if(b.getLoseNum() - c.getLoseNum() > 1){
					b.setLoseNum(b.getLoseNum() + 1);
				}else{
					c.setLoseNum(c.getLoseNum() + 1);
				}
			}else if(b.getLoseNum() >= c.getLoseNum()){
				b.setWinNum(b.getWinNum() + 1);
				b.setMin(b.getMin() + 2);
				if(a.getWinNum() - b.getWinNum() > 1){
					a.setLoseNum(a.getLoseNum() + 1);
				}else{
					c.setLoseNum(c.getLoseNum() + 1);
				}
			}else if(b.getLoseNum() >= a.getLoseNum()){
				b.setWinNum(b.getWinNum() + 1);
				b.setMin(b.getMin() + 2);
				a.setLoseNum(c.getLoseNum() + 1);
			}else if(c.getMin() <= a.getMin() || c.getMin() <= b.getMin()){
				c.setWinNum(c.getWinNum() + 1);
				c.setMin(c.getMin() + 2);
				if(a.getWinNum() - c.getWinNum() > 1){
					a.setLoseNum(a.getLoseNum() + 1);
				}else if(b.getLoseNum() - c.getLoseNum() > 1){
					b.setLoseNum(b.getLoseNum() + 1);
				}else{
					c.setDrawNum(b.getDrawNum() + 1);
					c.setMin(c.getMin() + 1);
					if(b.getMin() > a.getMin()){
						a.setMin(a.getMin() + 1);
						a.setDrawNum(a.getDrawNum() + 1);
					}else{
						b.setMin(b.getMin() + 1);
						b.setDrawNum(b.getDrawNum() + 1);
					}
				}
			}
			if((a.getWinNum() > c.getWinNum() && a.getWinNum() > b.getWinNum()) 
					&& (b.getLoseNum() < a.getLoseNum() && b.getLoseNum() < c.getLoseNum() ) 
						&& (c.getMin() > a.getMin() && c.getMin() > b.getMin()) ){
				System.out.println("a win :" + a.getWinNum() + "  lose :" + a.getLoseNum() + "  drawnum :" + a.getDrawNum() + "  min :" + a.getMin());
				System.out.println("b win :" + b.getWinNum() + "  lose :" + b.getLoseNum() + "  drawnum :" + b.getDrawNum() + "  min :" + b.getMin());
				System.out.println("c win :" + c.getWinNum() + "  lose :" + c.getLoseNum() + "  drawnum :" + c.getDrawNum() + "  min :" + c.getMin());
				System.out.println("roundNum : " + roundNum);
				break;
			}else{
				System.out.println("a win :" + a.getWinNum() + "  lose :" + a.getLoseNum() + "  drawnum :" + a.getDrawNum() + "  min :" + a.getMin());
				System.out.println("b win :" + b.getWinNum() + "  lose :" + b.getLoseNum() + "  drawnum :" + b.getDrawNum() + "  min :" + b.getMin());
				System.out.println("c win :" + c.getWinNum() + "  lose :" + c.getLoseNum() + "  drawnum :" + c.getDrawNum() + "  min :" + c.getMin());
				System.out.println("-------------------------------------------------------");
				roundNum ++ ;
			}
		}
	}
	
}
31 楼 q472732639 2009-09-13  
package filter;

public class TeamObj {

	private int min;
	
	private int winNum;
	
	private int loseNum;
	
	private int drawNum;

	public int getMin() {
		return min;
	}

	public void setMin(int min) {
		this.min = min;
	}

	public int getWinNum() {
		return winNum;
	}

	public void setWinNum(int winNum) {
		this.winNum = winNum;
	}

	public int getLoseNum() {
		return loseNum;
	}

	public void setLoseNum(int loseNum) {
		this.loseNum = loseNum;
	}

	public int getDrawNum() {
		return drawNum;
	}

	public void setDrawNum(int drawNum) {
		this.drawNum = drawNum;
	}
	
}


重新发...
30 楼 q472732639 2009-09-13  

/**
*
* @author q472732639
*
*/
public class Test {


public static void main(String [] args){
TeamObj a = new TeamObj(); //A队
TeamObj b = new TeamObj(); //B队
TeamObj c = new TeamObj(); //C队
int roundNum = 1; //回合数
/*
* 下面的纯粹就是按照题意所写的判断 不精湛 粗略的理解为a是必须赢数多.但不一定不输,
* b必须是输数少,但不一定去赢,c是积分一定要高,但一定要让A,B两组积分低的情况下不影响战绩..全是废话
*/
for(int i = 0 ; i < roundNum ; i ++){
if(a.getWinNum() <= b.getWinNum()
|| a.getWinNum() <= c.getWinNum()){
a.setWinNum(a.getWinNum() + 1);
a.setMin(a.getMin() + 2);
if(b.getLoseNum() - c.getLoseNum() > 1){
b.setLoseNum(b.getLoseNum() + 1);
}else{
c.setLoseNum(c.getLoseNum() + 1);
}
}else if(b.getLoseNum() >= c.getLoseNum()){
b.setWinNum(b.getWinNum() + 1);
b.setMin(b.getMin() + 2);
if(a.getWinNum() - b.getWinNum() > 1){
a.setLoseNum(a.getLoseNum() + 1);
}else{
c.setLoseNum(c.getLoseNum() + 1);
}
}else if(b.getLoseNum() >= a.getLoseNum()){
b.setWinNum(b.getWinNum() + 1);
b.setMin(b.getMin() + 2);
a.setLoseNum(c.getLoseNum() + 1);
}else if(c.getMin() <= a.getMin() || c.getMin() <= b.getMin()){
c.setWinNum(c.getWinNum() + 1);
c.setMin(c.getMin() + 2);
if(a.getWinNum() - c.getWinNum() > 1){
a.setLoseNum(a.getLoseNum() + 1);
}else if(b.getLoseNum() - c.getLoseNum() > 1){
b.setLoseNum(b.getLoseNum() + 1);
}else{
c.setDrawNum(b.getDrawNum() + 1);
c.setMin(c.getMin() + 1);
if(b.getMin() > a.getMin()){
a.setMin(a.getMin() + 1);
a.setDrawNum(a.getDrawNum() + 1);
}else{
b.setMin(b.getMin() + 1);
b.setDrawNum(b.getDrawNum() + 1);
}
}
}
if((a.getWinNum() > c.getWinNum() && a.getWinNum() > b.getWinNum())
&& (b.getLoseNum() < a.getLoseNum() && b.getLoseNum() < c.getLoseNum() )
&& (c.getMin() > a.getMin() && c.getMin() > b.getMin()) ){
System.out.println("a win :" + a.getWinNum() + "  lose :" + a.getLoseNum() + "  drawnum :" + a.getDrawNum() + "  min :" + a.getMin());
System.out.println("b win :" + b.getWinNum() + "  lose :" + b.getLoseNum() + "  drawnum :" + b.getDrawNum() + "  min :" + b.getMin());
System.out.println("c win :" + c.getWinNum() + "  lose :" + c.getLoseNum() + "  drawnum :" + c.getDrawNum() + "  min :" + c.getMin());
System.out.println("roundNum : " + roundNum);
break;
}else{
System.out.println("a win :" + a.getWinNum() + "  lose :" + a.getLoseNum() + "  drawnum :" + a.getDrawNum() + "  min :" + a.getMin());
System.out.println("b win :" + b.getWinNum() + "  lose :" + b.getLoseNum() + "  drawnum :" + b.getDrawNum() + "  min :" + b.getMin());
System.out.println("c win :" + c.getWinNum() + "  lose :" + c.getLoseNum() + "  drawnum :" + c.getDrawNum() + "  min :" + c.getMin());
System.out.println("-------------------------------------------------------");
roundNum ++ ;
}
}
}

}


那个队伍对象就不写了
楼上说的对先用方程式找好数据之间的关系.然后列出来.在解出来就不难了..我这小白代码只是看下..
29 楼 bookong 2009-09-10  
lindakun 写道

其实zhouzhao21用的穷举法是没错的,“乙(平)=甲(平)+丙(平) ”是不成立的, 11 < 4 + 9 = 13 ,为什么会多了两场呢?其实是甲队和丙队之间的比赛的。其实只要满足所有队伍平场的总数为偶数就可以用穷举法的。


你说的对,我弄错了,zhouzhao21这个结果应该是正确的。
28 楼 lugionline 2009-09-10  
lindakun 写道
zhouzhao21 写道
boywukong 写道
lindakun 写道
个人写的数学解决方法:
         
  综上所述:
            只要满足
                     Y1 > Y3 && X3 > X2
                     即 甲输的场数多于丙输的场数 同时 丙赢的场数多于乙赢的场数
                    (例如:
                      甲 赢3 平3 输3
                      乙 赢2 平4 输3
                      丙 赢3 平4 输2
                     )
            丙队便可以是第一名
 
 


   这个显然不正确,比赛结果不可能总平的场数为:甲平3,乙平4,丙平4的情况,或者说,两两队相比的比赛,结果不可能出现"甲平,乙负"的情况,平局的总场次一定是个偶数.
   我思考过这个问题,但是能力太低不能得出答案,这个问题我化简为六元的不等式组,无奈数学太差,不会解多元不等式组.前面有的楼说这个是解方程的问题,其实从概念上就错了,方程首先是等式,如果有解,一定是确定解,而这个问题我认为如果有解,也无法给出确定解,因为它有多个不等式条件约束.
   期待大神给出解答!


joyfun 的回答是正确的。


呵呵,我检查了一下,其实这里只是我的疏忽,解法没错,只是最后忘记了考虑实际的情况
         修正:只要在最后在再加一个条件 甲乙丙平场的总数为偶数就行
                 例如:
                      甲 赢10 平2 输10   总分:32
                      乙 赢8  平8  输6    总分:32
                      丙 赢9  平6  输7    总分:33
                 因此丙队赢得第一是有可能的;只要满足上面的三个条件;(Y1 > Y3 && X3 > X2 && 甲乙丙平场的总数为偶数)


显然不对么,很容易举出反例了,比方

甲赢 3 场
甲输 2 场
甲平 0 场

乙赢 1 场
乙输 0 场
乙平 4 场

丙赢 2 场
丙输 1 场
丙平 2 场

甲输 2 场 > 丙输 1 场
丙赢 2 场 > 乙输 0 场
平场总数是 6 偶数

不过甲积分 9 , 丙积分 8
27 楼 lindakun 2009-09-10  
bookong 写道
zhouzhao21 写道
丙是可以第一的。用穷举可以算的出来。如
     甲 胜8 平4 负10
   乙 胜6 平11 负5
   丙 胜7 平9 负6
但用穷举解题只是下下之选。重在推理过程。
不知道答案的朋友也请支持下吧。认会解的人看到。
重在过程。


质疑你穷举出的结果:
我们看乙队,它平了11场(是3队里最多的),我们站在它的视角,这11场不是跟甲队踢就是跟丙队比赛没错吧?所以:
乙(平)=甲(平)+丙(平)
那么看看你的例子: 11 < 4 + 9 = 13  显然是有问题的!

同理,甲队胜利了8场,那么应该
甲(胜)=乙(负)+丙(负)
看你的例子: 8 < 5 + 6 = 11


其实zhouzhao21用的穷举法是没错的,“乙(平)=甲(平)+丙(平) ”是不成立的, 11 < 4 + 9 = 13 ,为什么会多了两场呢?其实是甲队和丙队之间的比赛的。其实只要满足所有队伍平场的总数为偶数就可以用穷举法的。
26 楼 lindakun 2009-09-10  
zhouzhao21 写道
boywukong 写道
lindakun 写道
个人写的数学解决方法:
         
  综上所述:
            只要满足
                     Y1 > Y3 && X3 > X2
                     即 甲输的场数多于丙输的场数 同时 丙赢的场数多于乙赢的场数
                    (例如:
                      甲 赢3 平3 输3
                      乙 赢2 平4 输3
                      丙 赢3 平4 输2
                     )
            丙队便可以是第一名
 
 


   这个显然不正确,比赛结果不可能总平的场数为:甲平3,乙平4,丙平4的情况,或者说,两两队相比的比赛,结果不可能出现"甲平,乙负"的情况,平局的总场次一定是个偶数.
   我思考过这个问题,但是能力太低不能得出答案,这个问题我化简为六元的不等式组,无奈数学太差,不会解多元不等式组.前面有的楼说这个是解方程的问题,其实从概念上就错了,方程首先是等式,如果有解,一定是确定解,而这个问题我认为如果有解,也无法给出确定解,因为它有多个不等式条件约束.
   期待大神给出解答!


joyfun 的回答是正确的。


呵呵,我检查了一下,其实这里只是我的疏忽,解法没错,只是最后忘记了考虑实际的情况
         修正:只要在最后在再加一个条件 甲乙丙平场的总数为偶数就行
                 例如:
                      甲 赢10 平2 输10   总分:32
                      乙 赢8  平8  输6    总分:32
                      丙 赢9  平6  输7    总分:33
                 因此丙队赢得第一是有可能的;只要满足上面的三个条件;(Y1 > Y3 && X3 > X2 && 甲乙丙平场的总数为偶数)
25 楼 lugionline 2009-09-09  
zhouzhao21 写道
fudc 写道
Win[x] + Tie[x] + Los[x] = Win[y] + Tie[y] + Los[y] = Win[z] + Tie[z] + Los[z]  -- (2)

这个是不成立的吧?问题只是说 ‘“每两队之间都比赛了同样多的场数”,并不是每个队都比赛了同样多的场数。


‘“每两队之间都比赛了同样多的场数”,并不是每个队都比赛了同样多的场数。    
     确实是这样,不过
        Win[x] + Tie[x] + Los[x] = Win[y] + Tie[y] + Los[y] = Win[z] + Tie[z] + Los[z]  -- (2)
包涵在这个条件之中,是条件的子集。也不能说不成立。只是将条件的范围缩小了。


完全可以证明
    每两队之间都比赛了同样多的场数

    Win[x] + Tie[x] + Los[x] = Win[y] + Tie[y] + Los[y] = Win[z] + Tie[z] + Los[z]
是等价的,并不存在条件返回放大或者缩小

假设 每两队之间都比赛了同样多的场数,那么有

Match[x, y] = T
Match[y, z] = T
Match[z, x] = T

所以各队的比赛场次是 Match[x] = Match[y] = Match[z] = 2 * T

反过来
假设 Win[x] + Tie[x] + Los[x] = Win[y] + Tie[y] + Los[y] = Win[z] + Tie[z] + Los[z]
也即 Match[x] = Match[y] = Match[z] = T


Match[x, y] = a
Match[y, z] = b
Match[z, x] = c


Match[x] = a + c
Match[y] = a + b
Match[z] = b + c
也即 a + c = a + b = b + c = T
推出 a = b = c

命题得证



24 楼 bookong 2009-09-09  
zhouzhao21 写道
丙是可以第一的。用穷举可以算的出来。如
     甲 胜8 平4 负10
   乙 胜6 平11 负5
   丙 胜7 平9 负6
但用穷举解题只是下下之选。重在推理过程。
不知道答案的朋友也请支持下吧。认会解的人看到。
重在过程。


质疑你穷举出的结果:
我们看乙队,它平了11场(是3队里最多的),我们站在它的视角,这11场不是跟甲队踢就是跟丙队比赛没错吧?所以:
乙(平)=甲(平)+丙(平)
那么看看你的例子: 11 < 4 + 9 = 13  显然是有问题的!

同理,甲队胜利了8场,那么应该
甲(胜)=乙(负)+丙(负)
看你的例子: 8 < 5 + 6 = 11
23 楼 bookong 2009-09-09  
monsterjiao 写道
如果喜欢足球比赛并关注得的话,心算一下应该就能出来吧:
一个简单的例子就能证明丙有夺冠的可能:
队伍  胜   负   平    总积分
甲    3    5   0      9
乙    1    1   6      8  
丙    2    2   4      10
此题解法:
先证明丙会超过乙的积分:乙比并少输,但是输球是0分,而胜是3分,平是1分,那么丙只要将比乙多输的一场放到胜场上,也就是说丙比乙多赢也多输了一场,而平局自然就是乙比丙多了两场,算下来3-2=1,丙超过了乙的积分。
然后证明丙会超过甲的积分:甲比丙多赢一场,光看胜场是多了3分,而甲比并多输的场是可以无限多加入为N吧(反正题目中又没有说三队之前是进行了多少场比较),那么丙的平局的场次自然就比甲多出N-1,(N-1)*1>3的情况很容易出现吧。
希望能帮助到你


对不起,我真没看懂你的例子,我有两个疑问:
1、看看乙吧,1×3+6在什么情况下能等于8?
2、甲负了5场,乙和丙胜利加起来1+2=3,那两场是跟谁?
22 楼 monsterjiao 2009-09-09  
如果喜欢足球比赛并关注得的话,心算一下应该就能出来吧:
一个简单的例子就能证明丙有夺冠的可能:
队伍  胜   负   平    总积分
甲    3    5   0      9
乙    1    1   6      8  
丙    2    2   4      10
此题解法:
先证明丙会超过乙的积分:乙比并少输,但是输球是0分,而胜是3分,平是1分,那么丙只要将比乙多输的一场放到胜场上,也就是说丙比乙多赢也多输了一场,而平局自然就是乙比丙多了两场,算下来3-2=1,丙超过了乙的积分。
然后证明丙会超过甲的积分:甲比丙多赢一场,光看胜场是多了3分,而甲比并多输的场是可以无限多加入为N吧(反正题目中又没有说三队之前是进行了多少场比较),那么丙的平局的场次自然就比甲多出N-1,(N-1)*1>3的情况很容易出现吧。
希望能帮助到你
21 楼 zhouzhao21 2009-09-08  
fudc 写道
因为甲赢的场数就是乙和丙输的场数的和,即:W(甲)=L(乙)+L(丙)

这个公式是不对的吧?!
因为乙丙之间可以有输赢的,只能说W(甲)<L(乙)+L(丙)

W(甲)=L(乙)对甲输+L(丙)对甲输

L(乙)+L(丙) >= L(乙)对甲输+L(丙)对甲输


W(甲) <= L(乙)+L(丙)
同时也是取子集。
20 楼 zhouzhao21 2009-09-08  
fudc 写道
Win[x] + Tie[x] + Los[x] = Win[y] + Tie[y] + Los[y] = Win[z] + Tie[z] + Los[z]  -- (2)

这个是不成立的吧?问题只是说 ‘“每两队之间都比赛了同样多的场数”,并不是每个队都比赛了同样多的场数。


‘“每两队之间都比赛了同样多的场数”,并不是每个队都比赛了同样多的场数。    
     确实是这样,不过
        Win[x] + Tie[x] + Los[x] = Win[y] + Tie[y] + Los[y] = Win[z] + Tie[z] + Los[z]  -- (2)
包涵在这个条件之中,是条件的子集。也不能说不成立。只是将条件的范围缩小了。
19 楼 fudc 2009-09-08  
推理过程:
a代表甲
b代表乙
c代表丙
1代表赢,
2代表平
3代表输(没有用到)

a1 > b1
   > c1

b1 + b2 > a1 + a2
       > c1 + c2

隐含条件
a2 <= b2 + c2
b2 <= a2 + c2
c2 <= a2 + b2
否则这么多平局跟谁平去?



3a1 + a2
3b1 + b2
3c1 + c2
之中
3c1 + c2 是否可能是最大的。


这里我要找到一种可能性使c是最大的,那么我就可以通过合理假设尽可能使a和b最小,使c最大。当然是在满足所有限制条件的情况下。

合理假设:
1. b1 = 0; 如果b没有赢过,积分无疑是最可能小的情况了。这样3b1+b2分数才尽可能小。
2. c1 = a1 – 1。3c1+c2要最大。那么再跟3a1+a2比较的时候,就要尽可能在赢的场数上跟a1差距缩小,这样分数才会最大嘛。因为c1 + c2 < b2,c1<a1,所以理想情况是c1 = a1 – 1,c2用足。这样3c1+c2分数才尽可能大。
3. b2 = a2 + c2。b的平局都是和a和c打的。如果a和c除了跟b的平局外还互相有平局的话,那么c2会比没有ac互相平局的时候大,因为c1 + c2 < b2, 所以c和a每多一场平局,c1就不得不少一场,就少了两分(赢变成了平,3-1=2)。这在跟b比较的时候是不利的。所以ac没有互相平局才最有利。这样3c1+c2分数才尽可能大。
4. c2 =a2 + 4。由于希望3c1+c2>3a1+a2,应用假设2 (c1 = a1 – 1),3a1 – 3 + c2 > 3a1 + a2, 那么c2 > a2 + 3。所以需要c2 >=a2 + 4成立,3c1+c2>3a1+a2才成立。如果c2 =a2 + 5或者更多的话,因为c1 + c2 < b2的限制,c2每多一场,c1就少一场,所以c2刚刚比a2多4场是最有利的。这样3c1+c2分数才尽可能大。


经过上述合理假设:
a: 3a1 + a2
b: 3b1 + b2 = b2 = a2 + c2= 2a2 + 4
c: 3c1 + c2 = 3a1 – 3 + a2 + 4 = 3a1 + a2 + 1

问题演变为是否存在合理数值使得
3a1 + a2 + 1 > 2a2 + 4

3a1 – a2 > 3

a1如果取值为1,那么a2需为负数
a1如果取值为2, 那么a2可以是1或者2

验证:
a1 = 2, a2 = 1    7
b1 = 0, b2 = 6    6
c1 = 1, c2 = 5    8
成立

a1 = 2, a2 = 2    8
b1 = 0, b2 = 8    8
c1 = 1, c2 = 6    9
也成立
18 楼 dxueshen 2009-09-08  
线性规划:单纯形法!
17 楼 fudc 2009-09-08  
因为甲赢的场数就是乙和丙输的场数的和,即:W(甲)=L(乙)+L(丙)

这个公式是不对的吧?!
因为乙丙之间可以有输赢的,只能说W(甲)<L(乙)+L(丙)

W(甲)=L(乙)对甲输+L(丙)对甲输

L(乙)+L(丙) >= L(乙)对甲输+L(丙)对甲输
16 楼 fudc 2009-09-08  
Win[x] + Tie[x] + Los[x] = Win[y] + Tie[y] + Los[y] = Win[z] + Tie[z] + Los[z]  -- (2)

这个是不成立的吧?问题只是说 “每两队之间都比赛了同样多的场数”,并不是每个队都比赛了同样多的场数。

相关推荐

    数字逻辑推理题 提供练习

    ### 数字逻辑推理题知识点解析 #### 1. 题目分析与解题思路 **数字推理题**是计算机专业笔试中常见的题型之一,这类题目主要考察考生的逻辑思维能力和数学运算能力。下面将对给定的部分题目进行详细解析。 #### 2...

    逻辑推理题及答案

    根据给定的信息,我们将对每一道逻辑推理题及其答案进行详细的解析。 ### 第一题 题目描述:在某个地方有两位医生,一位是内科医生,另一位不是。这两位医生中有一位是外科医生,并且其中的一位医生不是外科医生。...

    逻辑推理题精选300道详解_Password_Removed(1).pdf

    ### 逻辑推理题精选300道详解 #### “社会人”假设的管理方式 - **知识点概述**:“社会人”假设是组织行为学中的一个重要概念,它强调人际关系的重要性超过了物质利益,在工作场所中,良好的人际交往对于提高员工...

    逻辑推理题的表格处理法

    逻辑推理题的表格处理法是一种高效解决这类问题的策略,尤其适用于那些包含多个条件和变量的问题。这种方法通过将所有信息整理成清晰的表格形式,帮助我们系统地分析和排除错误选项,最终找到正确的答案。 首先,...

    7-EPI综合能力题库----逻辑推理题精选100道(含解析和答案).pdf

    根据文件标题“7-EPI综合能力题库----逻辑推理题精选100道(含解析和答案).pdf”,我们可以得知该题库是银行招聘考试中可能用到的资料。在银行招聘考试中,逻辑推理能力是一项重要的考察点,它主要测试考生的抽象思维...

    逻辑题 各大公司笔试

    1. **逻辑题**:逻辑题通常包括逻辑推理、逻辑判断、图形推理等不同类型。它们要求考生能够识别和应用基本的逻辑规则,如假设、推理、归纳和演绎。例如,可能需要你找出一系列数字或图形的规律,并预测下一个数字或...

    公务员考试-公务员考试逻辑推理题技巧大全.docx

    公务员考试逻辑推理题技巧大全 公务员考试逻辑推理题技巧大全是公务员考试中的一种重要题型,旨在考察考生的逻辑思维能力和分析能力。本资源提供了逻辑推理题的技巧大全,涵盖了条件有矛盾真假的分辨、逻辑矛盾的...

    行测逻辑推理题及答案解析

    ### 行测逻辑推理题及答案解析 #### 一、逻辑推理解题方法概述 逻辑推理题在各类考试中占据重要地位,对于培养考生的逻辑思维能力有着不可替代的作用。解决逻辑推理题的关键在于掌握一系列有效的解题技巧,常见的...

    公务员逻辑推理练习题及答案.doc

    "逻辑推理练习题及答案" 以下是公务员逻辑推理练习题及答案的知识点摘要: 逻辑推理的定义和重要性 逻辑推理是指通过分析和评估信息,作出合理的结论和决策的过程。逻辑推理在我们的日常生活和职业中扮演着非常...

    公务员常考各类逻辑推理题.doc

    - 在某些逻辑推理题中,可以通过排除不符合条件的选项来找到正确答案。例如试题1的第2题,三位教官中只有一位是正确的。通过分析张教官和孙教官的陈述,我们知道他们两人中必有一真一假,因此周教官的陈述必定错误...

    五年级奥数逻辑推理题讲座及练习答案.doc

    综上所述,"五年级奥数逻辑推理题讲座及练习答案"涉及的核心知识点是逻辑推理的方法及其应用,通过实例解析和练习题,旨在培养学生的逻辑思维和问题解决技巧。通过深入理解和实践这些方法,学生可以提升自己的逻辑...

    逻辑推理快速解题技巧大全

    【逻辑推理快速解题技巧大全】 在逻辑推理的领域中,快速解题技巧是至关重要的。这类技巧常常在公务员考试、逻辑思维训练等场合中出现,帮助考生在有限的时间内高效解决问题。以下将详细阐述几种核心技巧。 1. **...

    面向计算机科学的数理逻辑课后习题答案

    通过这两份习题解答,学生不仅可以检验自己对数理逻辑的理解,还能进一步巩固理论知识,提升逻辑推理能力。这在计算机科学领域尤其重要,因为逻辑是编程语言设计、编译器构造、形式验证和自动定理证明等领域的基石。...

    面试常见智力题(逻辑分析题及答案)

    逻辑分析题是指通过逻辑分析和推理来解决问题的智力题。这种题目通常具有多种答案或无明确答案,要求应聘者具备灵活的思维能力和逻辑分析能力。例如,例题 1 中,你让工人为你工作 7 天,给工人的回报是一根金条。...

    75道程序员面试逻辑测试题内含答案.pdf,这是一份不错的文件

    程序员面试逻辑测试题内含答案.pdf 这是一份不错的文件,包含了75道程序员面试逻辑测试题,内含答案。该文件对应的标签为面试、文档资料、职场和发展、文档。 在这份文件中,我们可以找到许多有趣的逻辑测试题,...

    NIIT逻辑测试题答案

    3. 逻辑题答案A:可能是一个基于逻辑推理的问题,例如:如果A发生,则B必然发生;如果B不发生,则C必然发生等。解答时需要理清事件之间的因果关系。 4. 逻辑题答案B:这可能是一道涉及逻辑悖论或者矛盾的问题,需要...

    小学数学逻辑推理题精选100题.doc

    这些题目都是小学数学逻辑推理题,旨在锻炼孩子们的逻辑思维能力和问题解决技巧。这些题目通常包含了一些基础的比较、推理和排除法的概念。 1. 题目1和5是关于速度的比较,通过排除法确定最快和最慢的兔子或人。这...

    逻辑推理能力测试模拟试题.doc

    这些逻辑推理题目的解答需要我们仔细阅读信息,理解题目的逻辑结构,并运用逻辑推理能力找到最合适的答案。通过这样的练习,可以提升我们的逻辑思维能力和问题解决技巧,对于日常生活、学习和工作都有着重要的作用。

Global site tag (gtag.js) - Google Analytics