选择题:
题一:
1、已知函数的原型是: int fun(char b[10], int *a); ,设定义: char c[10];int d; ,正确的调用语句是( )
A: fun(c,&d); B: fun(c,d); C: fun(&c,&d); D: fun(&c,d);
题二:
2、请问下列表达式哪些会被编译器禁止【多选】( )
int a = 248, b = 4;
int const *c = 21;
const int *d = &a;
int *const e = &b;
int const * const f = &a;A: *c = 32; B: *d = 43 C: e=&a D: f=0x321f
题三:
3、以下程序的输出结果为( )
#include <stdio.h>
int i;
void prt()
{
for (i = 5; i < 8; i++)
printf("%c", '*');
printf("\t");
}int main()
{
for (i = 5; i <= 8; i++)
prt();
return 0;
}A: *** B: *** *** *** *** C: *** *** D: * * *
题四:
4、下面代码段的输出是( )
#include <stdio.h>
int i;
void prt()
{
for (i = 5; i < 8; i++)
printf("%c", '*');
printf("\t");
}
int main()
{
for (i = 5; i <= 8; i++)
prt();
return 0;
}
A: -6 B: 12 C: 0 D: -12
题五:
5、下列不能实现死循环的是()
A:while(1){} B:for(;1;){}
C:do{}while(1); D:for(;0;){}
编程题:
题一:记负均正
示例1
输入:
11
1 2 3 4 5 6 7 8 9 0 -1
输出:
1 5.0
思路一:
本题主要难点在于:nan(ind)-----得到不确定的一个数字;其余的就是输入,判断,记录。
num/counint > 0 ?num / counint:0 解决无法得到不确定的一个数字
#include <stdio.h> int main() { int n = 0; int arr[2000] = {0}; while (scanf("%d", &n) != EOF) { int i = 0; int count = 0; int counint = 0; float num = 0; //循环判断是否正负 for (i = 0; i < n; i++) { scanf("%d", arr + i); if (arr[i] < 0) { count++; } if (arr[i] > 0) { num += arr[i]; counint++; } } //nan(ind) //num/counint > 0 ?num / counint:0 解决无法得到不确定的一个数字 printf("%d %0.1f", count, num/counint > 0 ?num / counint:0); } return 0; }
题二:旋转数组的最小数字
旋转数组的最小数字_牛客题霸_牛客网 (nowcoder.com)
示例1
输入:
[3,4,5,1,2]
返回值:
1
思路一:
left记录开头,right记录结尾,mid记录中间节点,情况一:右边大于中间,说明最小值在左边;右边小于中间,说明最小值在右边;情况二:考虑有相同的数,此时结尾-1。最后将left节点值输出即最小值。
int minNumberInRotateArray(int* nums, int numsLen ) { //防止nums为NULL if(nums == NULL) { return 0; } int left = 0; int right = numsLen -1; //二分查找思路 while(left < right) { int mid = (left + right)/2; //如果右边大于中间,最小值在左边 if(nums[mid] < nums[right]) { right = mid; } //如果右边小于中间,最小值在右边 else if(nums[mid] > nums[right]) { left = mid+1; } //如果右边等于中间,退一个单位 else { right = right-1; } } return nums[left]; }
本人实力有限可能对一些地方解释和理解的不够清晰,可以自己尝试读代码,或者评论区指出错误,望海涵!