★★写在前面★★
本题库源自互联网,仅作为个人学习使用,记录C语言题目练习的过程,如果对你也有帮助,那就点个赞吧。
1、如下程序的功能是( )
#include
int main()
{
char ch[80] = "123abcdEFG*&";
int j;
puts(ch);
for(j = 0; ch[j] != '\0'; j++)
if(ch[j] >= 'A' && ch[j] <= 'Z')
ch[j] = ch[j] + 'e' - 'E';
puts(ch);
return 0;
}
A: 测字符数组ch的长度
B: 将数字字符串ch转换成十进制数
C: 将字符数组ch中的小写字母转换成大写
D: 将字符数组ch中的大写字母转换成小写
正确答案:D
答案解析:
#include
int main()
{
char ch[80] = "123abcdEFG*&"; //初始化一维数组
int j; //定义变量遍历数组控制下标
puts(ch); //第一次将字符串输出到屏幕
for(j = 0; ch[j] != '\0'; j++) //遍历字符串
if(ch[j] >= 'A' && ch[j] <= 'Z') //判断是否为大写字母
ch[j] = ch[j] + 'e' - 'E'; //如果为大写,那么把大写字母变成小写字母
puts(ch); //第二次将字符串输出到屏幕
return 0;
}
/*一个字母对应的大写和小写之间的ASCII码值相差32,而且小写的大于大写的。所以题中'e'和'E'之间的ASCII码值相
//差32(ch[j]+'e'-'E'相当于ch[j]+32)。一个字母从大写转化为小写就是在它自身上+32,小写转大写则是-32*/
2、对于代码段,下面描述正确的是( )
t=0;
while(printf("*"))
{
t++;
if (t<3)
break;
}
A: 其中循环控制表达式与0等价
B: 其中循环控制表达式与’0’等价
C: 其中循环控制表达式是不合法的
D: 以上说法都不对
正确答案:D
答案解析:print(“*”)函数调用的返回值是字符串中字符的个数,即为1。所以while后面的条件恒为真,所以循环控制表达式与’0’是等
价的(字符’0’不是0)。
3、以下程序运行时,若输入1abcedf2df<回车> 输出结果是( )
#include
int main()
{
char ch;
while ((ch = getchar()) != '\n')
{
if (ch % 2 != 0 && (ch >= 'a' && ch <= 'z'))
ch = ch - 'a' + 'A';
putchar(ch);
}
printf("\n");
return 0;
}
A: 1abcedf2df B: 1ABCEDF2DF C: 1AbCEdf2df D: 1aBceDF2DF
正确答案:C
答案解析:
#include
int main()
{
char ch; //定义一个字符变量
while ((ch = getchar()) != '\n') //输入字符变量
{
if (ch % 2 != 0 && (ch >= 'a' && ch <= 'z')) //判断:字符的ASCII码是奇数数同时也是小写吗?
ch = ch - 'a' + 'A'; //条件为真,就把小写转为大写,为假则原样输出
putchar(ch); //再打印到屏幕上
}
printf("\n");
return 0;
}
//1abcedf2df中,先排除数字ASCII码为偶数的有1、2、b、d、f,
//ASCII码为奇数的有a、c、e,所以转为大写为A、C、E。
4、下列条件语句中,功能与其他语句不同的是( )
A: if(a) printf(“%d\n”,x); else printf(“%d\n”,y);
B: if(a==0) printf(“%d\n”,y); else printf(“%d\n”,x);
C: if (a!=0) printf(“%d\n”,x); else printf(“%d\n”,y);
D: if(a==0) printf(“%d\n”,x); else printf(“%d\n”,y);
正确答案:D
答案解析:
A:a为真,打印x,a为假,打印y;
B:a为真,打印x,a为假, 打印y;
C:a为真,打印x,a为假,打印y;
D:a为真,打印y,a为假,打印x;
因此选D。
5、我们知道C语言的break 语句只能跳出离它最近的一层循环,可是有时候我们需要跳出多层循环,下列跳出多层循环的做法正确的是【多选】( )
A: 将程序写成函数用return结束函数,便可跳出循环
B: 修改外层循环条件例如
for( int i = 0 ; i < MAX1 ; i ++ )
{
for( int j = 0 ; j < MAX2 ; j ++ )
{
if( condition )
{
i = MAX1;
break;
}
}
}
C: 在外层循环设置判断条件例如
for( ; symbol != 1 && condition2 ; )
{
for( ; symbol != 1 && condition3 ; )
{
if( condition1 )
symbol = 1 ;
}
}
D: 在外层循环后面加入break例如
for( ; condition2 ; )
{
for( ; condition3 ; )
{
if( condition1 )
symbol = 1 ;
}
if( symbol == 1 )
break ;
}
1、给定一个长度为 n 的非降序数组和一个非负数整数 k ,要求统计 k 在数组中出现的次数
数据范围: 0≤n≤1000 , 0≤k≤100 ,数组中每个元素的值满足 0≤val≤100
牛客网【牛客网题号: JZ53 数字在升序数组中出现的次数】
示例:
输入:[1,2,3,3,3,3,4,5],3
返回值:4
int GetNumberOfK(int* nums, int numsLen, int k ) {
// write code here
//用方法:遍历计数法
int count=0;
if(numsLen==0)
return 0;
for(int i=0;i<numsLen;i++)
{
if(nums[i]==k)
count++;
}
return count;
}
2、整数转换。编写一个函数,确定需要改变几个位才能将整数A 转成整数B 。
leetcode【leetcode 题号:面试题 05.06. 整数转换】
示例:
输入:A = 29 (或者0b11101), B = 15(或者0b01111)
输出:2
输入:A = 1,B = 2
输出:2
//只完成题目的要求解答
int convertInteger(int A, int B){
int i=0;
int count=0;
for(i=0;i<32;i++)
{
if(((A>>i)&1)!=((B>>i)&1))
{
count++;
}
}
return count;
}
//真正实现由A转为B
#include
void convertInteger(int* PA, int* PB) {
for (int i = 0; i < 32; i++)
{
if (((*PA >> i) & 1) != ((*PB >> i) & 1))
{
if (((*PA >> i) & 1) == 0)
{
*PA |= 1 << i;
*PB &= ~(1 << i);
}
else
{
*PA &= ~(1 << i);
*PB |= 1 << i;
}
}
}
}
int main()
{
int A = 0;
int B = 0;
printf("请输入A,B的值:");
scanf("%d %d", &A, &B);
printf("转换前,A=%d,B=%d\n",A, B);
convertInteger(&A, &B);
printf("转换后,A=%d,B=%d\n", A, B);
return 0;
}
代码思路:
首先用单目操作符>>进行右移A的二进制位,然后跟1按位或,得到的值就是最低位的值,位为0或者1,B也进行同样操作,A和B的32位都进行比较,所以需要用到循环进行遍历,比较结果只有两种,相同和不同,对不同的二进制位我们需要对A的二进制位进行转换,需要转换的也有两种情况,从0转为1,或者从1转为0,先看第一种情况:从0转为1,只需要对该数进行按位与1,1的位置就在不同的那个二进制位除即可,注意需要进行赋值运算,因为>>或者<<和位运算都不会改变原数的值,然后看第二种情况:从1转为0,只需要对该数进行按位或上一个0,其余位全部按位或1即可,那么怎么同时得到这两种数呢,只需要将1左移,然后对左移后的数进行按位取反即可。