笔试题整理1

本文整理了四道笔试题目,涉及概率计算、整数逆序、找出高于平均分的学生和回文判断。通过这些题目,可以考察面试者的逻辑思维和编程能力。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.  4个人分牌,54张扑克牌,除去两张大小王剩下52张扑克牌。问红桃A和黑桃A同时被一个人拿到的概率是多少?
答:一个人分到红桃A的可能性是1/4,一个人分到黑桃A的可能性是1/4,乘起来就行了 ,1/16。

 

2. 将一整数逆序后放入一数组中(要求递归实现)


void convert(int *result, int n) {
if(n>=10)
convert(result+1, n/10);
*result = n%10;
}
int main(int argc, char* argv[]) {
int n = 123456789, result[20]={};
convert(result, n);
printf("%d:", n);
for(int i=0; i<9; i++)
printf("%d", result[i]);
}

 

 

3、求高于平均分的学生学号及成绩(学号和成绩人工输入)


double find(int total, int n) {
int number, score, average;
scanf("%d", &number);
if(number != 0) {
scanf("%d", &score);
average = find(total+score, n+1);
if(score >= average)
printf("%d:%d/n", number, score);
return average;
} else {
printf("Average=%d/n", total/n);
return total/n;
}
}
int main(int argc, char* argv[]) {
find(0, 0);
}

 

 

4、递归实现回文判断(如:abcdedcba就是回文,判断一个面试者对递归理解的简单程序)


int find(char *str, int n) {
if(n<=1) return 1;
else if(str[0]==str[n-1]) return find(str+1, n-2);
else return 0;
}

int main(int argc, char* argv[]) {
char *str = "abcdedcba";
printf("%s: %s/n", str, find(str, strlen(str)) ? "Yes" : "No");
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值