目录
1、请阅读以下程序,其运行结果是
- int main()
- {
- char c='A';
- if('0'<=c<='9') printf("YES");
- else printf("NO");
- return 0;
- }
YES
NO
YESNO
答案:A
2、假设编译器规定int
和 short
类型长度分别为32位和16位,若有下列C语言语句,则y的机器数为
- unsigned short x = 65530;
- unsigned int y = x;
答案:B
解析:
unsigned short
类型的x
变量2个字节保存了65530,十六进制形式为0xFFFA
,x
给y
赋值时会整型提升,而无符号数在提升时高位补0,其实就相当于把x
的值放在了y
的低2个字节的空间中,故选B
3、下列程序的输出结果是什么
- #include
- int main()
- {
- int n = 1001;
- int ans = 0;
- for(int i = 1; i <= n; ++i)
- {
- ans ^= i % 3;
- }
- printf("%d",ans);
- return 0;
- }
答案:B
解析:
i % 3
的值按1、2、0循环,可推算出ans
按1、3、3、2、0、0循环,循环进行1001次,而1001%6=5,也就是ans
按规律得到的第5个数为最终结果,故ans=0
4、C 语言中,下列运算符优先级最高的是
答案:A
解析:
单目运算符的优先级通常都比较高,具体情况可查阅运算符优先级表格
5、要使a
的低四位翻转,需要进行操作是
a|0xF
a&0xF
a^0xF
~a
答案:C
解析:
十六进制数0xF
(十进制为15)是4位1即,参与运算时整型提升,高位都是0。低四位和1异或,0^1
是1,1^1
是0;高位和0异或,0^0
是0,1^0
是1。故而可以通过异或F
使得a
的低四位翻转,并保持高位不变
题目链接:数字颠倒_牛客题霸_牛客网 (nowcoder.com)
描述
输入一个整数,将这个整数以字符串的形式逆序输出
程序不考虑负数的情况,若数字含有0,则逆序形式也含有0,如输入为100,则输出为001
数据范围:0≤ n≤
输入描述:
输入一个int整数
输出描述:
将这个整数以字符串的形式逆序输出
思路解析:
本题可以考虑使用字符串逆序输出的思路对本题进行解决,需要注意的是strlen
函数计算的是字符个数,此时遍历数组的最后一个元素的下标为长度减1
参考代码:
- #include
- #include
-
- int main() {
- int num = 0;
- scanf("%d", &num);
- char str[100] = {0};
- sprintf(str, "%d", num);
- int len = strlen(str);
- for (int i = len - 1; i >= 0; i--) {
- printf("%c", str[i]);
- }
- return 0;
- }
题目链接:单词倒排_牛客题霸_牛客网 (nowcoder.com)
描述
对字符串中的所有单词进行倒排。
说明:
1、构成单词的字符只有26个大写或小写英文字母;
2、非构成单词的字符均视为单词间隔符;
3、要求倒排后的单词间隔符以一个空格表示;如果原字符串中相邻单词间有多个间隔符时,倒排转换后也只允许出现一个空格间隔符;
4、每个单词最长20个字母;
数据范围:字符串长度满足 1≤ n≤10000
输入描述:
输入一行,表示用来倒排的句子
输出描述:
输出句子的倒排结果
思路解析:
本题可以考虑使用二维数组进行求解,每一行用于存一个单词,每一列放一个字母
首先是输入,可以考虑用死循环持续读取输入知道遇到'\n'
为止,在C语言中,根据scanf
的特点,在读取字符串时会跳过空白字符,而本题中题目说明了构成单词的字符只有大小写字母,所以在输入时需要限制输入的字符集合在a-z以及A-Z,即scanf("%[a-z|A-Z]", str[i])
,而因为scanf的返回值是实际成功读取到的字符的个数,故当其返回值非0时,说明此时输入了单词,输入完一个单词后换到二维数组的下一行即可
接着是输出,因为当前二维数组每一行存储的是一个单词,只要是有字母的位置就不会停止读取,那么对初始化全部为0的数组来说,只需要反向输出即可,但是输出时需要注意是使用%c还是%s,如果用%s
就不需要考虑列,%s在输出一行单词时会一直读到遇到'\0'
为止
参考代码:
- #include
-
- int main() {
- char str[128][21] = {0};
- int i = 0;
- int ret = 0;
- while (1) {
- ret = scanf("%[a-z|A-Z]", str[i]);
- if(getchar() == '\n')
- {
- break;
- }
- if (ret) {
- i++;
- }
- }
- for (int j = i; j >= 0; j--) {
- printf("%s ", str[j]);
- }
- return 0;
- }