5位运动员参加了10米台跳水比赛,有人让他们预测比赛结果
A选手说:B第二,我第三;
B选手说:我第二,E第四;
C选手说:我第一,D第二;
D选手说:C最后,我第三;
E选手说:我第四,A第一;
比赛结束后,每位选手都说对了一半,请编程确定比赛的名次。
#include<stdio.h>
#include<stdlib.h>
//5位运动员参加了10米台跳水比赛,有人让他们预测比赛结果
//A选手说:B第二,我第三; ----->A = 3 && B != 2 || A != 3 && B = 2
//B选手说:我第二,E第四; ----->B = 2 && E != 4 || B != 2 && E = 4
//C选手说:我第一,D第二; ------>C = 1 && D != 2 || C != 1 && D = 2 无论ABCDE为何值,ABCDE只能是1 2 3 4 5随机数的一个
//D选手说:C最后,我第三; ----->C = 5 && D != 3 || C != 5 && D = 3 所以有A*B*C*D*E = 120;为定值
//E选手说:我第四,A第一; ----->E = 4 && A != 1 || E != 4 && A = 1
//比赛结束后,每位选手都说对了一半,请编程确定比赛的名次。
int main(){
int A = 0;
int B = 0;
int C = 0;
int D = 0;
int E = 0;
for(A = 0;A < 5;A++){
for(B = 0;B < 5;B++){
for(C = 0;C < 5;C++){
for(D = 0;D < 5;D++){
for(E = 0;E < 5;E++){
if(((A == 3)+(B == 2) == 1&&
(B == 2)+(E == 4) == 1&&
(C == 1)+(D == 2) == 1&&
(C == 5)+(D == 3) == 1&&
(E == 4)+(A == 1) == 1) == 1){
if(A*B*C*D*E == 120){
printf("A=%d,B=%d,C=%d,D=%d,E=%d",A,B,C,D,E);
}
}
}
}
}
}
}
system("pause");
return 0;
}
日本某地发生了一件谋杀案,警察通过排查确定杀人凶手必为4个
嫌疑犯的一个。以下为4个嫌疑犯的供词。
A说:不是我。
B说:是C。
C说:是D。
D说:C在胡说
已知3个人说了真话,1个人说的是假话。
现在请根据这些信息,写一个程序来确定到底谁是凶手。
#include<stdio.h>
#include<stdlib.h>
//2.
//日本某地发生了一件谋杀案,警察通过排查确定杀人凶手必为4个
//嫌疑犯的一个。以下为4个嫌疑犯的供词。
//A说:不是我。
//B说:是C。
//C说:是D。
//D说:C在胡说
//已知3个人说了真话,1个人说的是假话。
//现在请根据这些信息,写一个程序来确定到底谁是凶手。
int main(){
int murderer;
for(murderer = 'a';murderer < 'e';murderer++){
if(((murderer != 'a')+(murderer == 'c')+(murderer == 'd')+(murderer != 'd'))==3){
//if括号里为真时结果为1,假为0,所以三真一假结果为3
printf("凶手是%c\n",murderer);
}
}
system("pause");
return 0 ;
}
3.在屏幕上打印杨辉三角。
1
1 1
1 2 1
1 3 3 1
……
杨辉三角规律
前提:每行端点与结尾的数为1.
- 每个数等于它上方两数之和。
- 每行数字左右对称,由1开始逐渐变大。
- 第n行的数字有n+1项。
- 第n行数字和为2n。
- 第n行的m个数可表示为 C(n-1,m-1),即为从n-1个不同元素中取m-1个元素的组合数。
- 第n行的第m个数和第n-m+1个数相等 ,为组合数性质之一。
- 每个数字等于上一行的左右两个数字之和。可用此性质写出整个杨辉三角。即第n+1行的第i个数等于第n行的第i-1个数和第i个数之和,这也是组合数的性质之一。即 C(n+1,i)=C(n,i)+C(n,i-1)。
#include<stdio.h>
#include<stdlib.h>
#define N 10 //N为杨辉三角打印的行数
//1 row = 0;
//1 1 row = 1;
//1 2 1 row = 2;
//1 3 3 1 row = 3; //第n行的数字有n+1项。
int main(){
int row = 0;
int col = 0;
int arr[N][N];
//先打印每一行的第一个和最后一个
//每行端点与结尾的数为1.
for(row = 0;row < N;row++){
arr[row][0] = 1;
arr[row][row] = 1;
}
//打印中间部分
//每个数等于它上方两数之和
for(row = 2;row < N;row++){
for(col = 1;col < row;col++){
arr[row][col] = arr[row - 1][col - 1] + arr[row - 1][col];
// printf("%4d",arr[row][col]);
}
//printf("\n");
}
for(row=0;row<N;row++){
for(col=0;col<2*(N-row);col++){
printf(" ");//让直角三角形变为等腰三角形
}
for(col=0;col<=row;col++){
printf("%4d",arr[row][col]);
}
printf("\n");
}
return 0;
}