程序基础程序员必知:C/C++面试题
2011-08-12 11:49
309 查看
转自:http://edu.gamfe.com/tutor/d/14818.html
一、输入一个n ,然后在屏幕上打印出NxN 的矩阵!
例如,
输入一个3 ,则
1 2 3
8 9 4
7 6 5
输入一个4 ,则
1 2 3 4
12 13 14 5
11 16 15 6
10 9 8 7
参考答案:
二、朗讯面试题 :
There are two int variables: a and b, don‘t use “if”, “? :”, “switch” or other judgement statements, find out the biggest one of the two numbers.
参考答案:
方案一
int max = ((a+b)+abs(a-b)) / 2
方案二
int c = a -b;
char *strs[2] = {"a
大 ","b
大
"};
c = unsigned(c) >> (sizeof(int) * 8 - 1);
三、朗讯面试题 :如何打印出当前源文件的文件名以及源文件的当前行号?
参考答案:
四、朗讯面试题 :main 主函数执行完毕后,是否可能会再执行一段代码,给出说明?
参考答案:
五、朗讯面试题 :如何判断一段程序是由C 编译程序还是由C++ 编译程序编译的?
参考答案:
六、下面这道面试题怎么做(指针)?
参考答案:
七、定义 int **a[3][4], 则变量占有的内存空间为:
_____参考答案:
八、编写一个函数,要求输入年月日时分秒,输出该年月日时分秒的下一秒。如输入2004 年12 月31 日23 时59 分59 秒,则输出2005 年1 月1 日0 时0 分0 秒。
参考答案:
九、给出下面代码的输出
输出结果是:
一、输入一个n ,然后在屏幕上打印出NxN 的矩阵!
例如,
输入一个3 ,则
1 2 3
8 9 4
7 6 5
输入一个4 ,则
1 2 3 4
12 13 14 5
11 16 15 6
10 9 8 7
参考答案:
#include<stdio.h> #include<conio.h> #define N 10 void printCube(int a[] ,int n); void main() { int a ,n; printf("input n:\n"); scanf("%d",&n); printCube(&a[0],n); getch(); } void printCube(int a[] ,int n) { int i,j,round=1; int m=1; for(i=0;i<n;i++) a[0]=m++; for(i=n-1;i>=n/2;i--) { for(j=round;j<=i;j++) a[j]=m++; for(j=i;j>=round;j--) a[j-1]=m++; for(j=i;j>round;j--) a[j-1][round-1]=m++; for(j=round;j<i;j++) a[round][j]=m++; round++; } for(i=0;i<n;i++){ for(j=0;j<n;j++) printf("%3d",a[j]); printf("\n"); } }
二、朗讯面试题 :
There are two int variables: a and b, don‘t use “if”, “? :”, “switch” or other judgement statements, find out the biggest one of the two numbers.
参考答案:
方案一
int max = ((a+b)+abs(a-b)) / 2
方案二
int c = a -b;
char *strs[2] = {"a
大 ","b
大
"};
c = unsigned(c) >> (sizeof(int) * 8 - 1);
三、朗讯面试题 :如何打印出当前源文件的文件名以及源文件的当前行号?
参考答案:
通常使用的就是 __FILE__, __LINE__ ,在调试函数中利用 “%s","%ld", 打印就好了。 |
参考答案:
crt 会执行另一些代码,进行处理工作。 如果你需要加入一段在 main 退出后执行的代码,可以使用 atexit() 函数,注册一个函数。 语法: #include <stdlib.h> int atexit(void (*function")(void)); #include <stdlib.h> #include <stdio.h> void fn1( void ), fn2( void ), fn3( void ), fn4( void ); int main( void ) { atexit( fn1 ); atexit( fn2 ); atexit( fn3 ); atexit( fn4 ); printf( "This is executed first.\n" ); } void fn1() { printf( "next.\n" ); } void fn2() { printf( "executed " ); } void fn3() { printf( "is " ); } void fn4() { printf( "This " ); } |
参考答案:
c++ 编译时定义了 __cplusplus c 编译时定义了 _STDC_ |
#include<stdio.h> main(){ int c[3][3]={1,2,3,4,5,6,7,8,9}; for(int i=0;i<3;i++) for(int j=0;j<3;j++) printf("%ld\n",&c[j]); printf("-------------------------\n"); printf("%ld\n",(c+1)); printf("%ld\n",(*c+1)); printf("%ld\n",&c[0][0]); printf("%ld\n",**c); printf("%ld\n",*c[0]); if(int(c)==int(*c)) printf("equl"); } 为什么 c , *c 的值相等,( c+1 ),( *c+1 )的值不等 c , *c , **c ,代表什么意思? |
c 是第一个元素的地址, *c 是第一行元素的首地址,其实第一行元素的地址就是第一个元素的地址,这容易理解。 **c 是提领第一个元素。 为什么 c , *c 的值相等? int c 因为直接用 c 表示数组 c[0][0] printf("%ld\n",*c[0]); 语句已将指针移到数组头。 int(*c) 表示 c0 的值为 1 ,所以相等。 数组 c 的存放空间示意如下:(机器中是行优先存放的) c[0][0] c[0][1] c[0][2] c[1][0] c[1][1] c[1][2] c[2][0] c[2][1] c[2][2] c 是一个二维数组名,实际上它是一个指针常量,不能进行自加、自减运算,即: c++ 、 c-- 、 ++c 、 --c 都是不允许的; c : 数组名;是一个二维指针,它的值就是数组的首地址,也即第一行元素的首地址(等于 *c ),也 等于第一行第一个元素的地址( & c[0][0] );可以说成是二维数组的行指针。 *c : 第一行元素的首地址;是一个一维指针,可以说成是二维数组的列指针。 **c :二维数组中的第一个元素的值;即: c[0][0] 所以: c 和 *c 的值是相等的,但他们两者不能相互赋值,(类型不同); ( c + 1 ) : c 是行指针,( c + 1 )是在 c 的基础上加上二维数组一行的地址长度,即从 &c[0][0] 变到了 &c[1][0] ; ( *c + 1 ): *c 是列指针,( *c + 1 )是在 *c 的基础上加上二数组一个元素的所占的长度,即从 &c[0][0] 变到了 &c[0][1] 从而( c + 1 )和( *c + 1 )的值就不相等了 |
_____参考答案:
int **p; /*16 位下 sizeof(p)=2, 32 位下 sizeof(p)=4*/ 总共 3*4*sizeof(p) |
参考答案:
判断年份是否是闰年,月份的大小月, 月( 12 进制)、日(与闰年、大小月有关)、时( 24 进制)、分( 60 进制)、妙( 60 进制) |
float a = 1.0f; cout << (int)a << endl; cout << (int&)a << endl; // ( int&)a , 是什么意思,是生成一个对 a 的引用吗? cout << boolalpha << ( (int)a == (int&)a ) << endl; float b = 0.0f; cout << (int)b << endl; cout << (int&)b << endl; cout << boolalpha << ( (int)b == (int&)b ) << endl; |
1 1065353216 false 0 0 true |
相关文章推荐
- 程序员必知:C/C++面试题(10)
- EA&UML日拱一卒-0基础学习微信小程序(9)-C++程序员眼中的app.js
- C/C++程序员必知之内存基础知识
- 程序员必知:C/C++面试题(10)
- 程序员必知:C/C++面试题(9)
- 程序员必知:C/C++面试题(8)
- 程序员必知:C/C++面试题(7)
- C++基础小程序——走向程序员的第一步
- 程序员必知:C/C++面试题(1)
- 程序员必知的C/C++面试题
- 程序不稳定是因为C++基础不扎实
- 面试题七 C/C++ 骑士营救公主 骑士只能向右或者向下移动,遇到陷阱就死了,求骑士营救公主的所有路线-程序员面试题
- C/C++程序员面试题
- [ZZ] C/C++程序员应聘常见面试题深入剖析 (二)
- 程序员必知的10大基础实用算法
- 程序员面试题精选100题(52)-C++面试题(1)
- C/C++程序员应聘常见面试题深入剖析
- C++_程序员_Protocol_Buffers_基础指南
- 程序员面试题精选100题(52)-C++面试题(1)
- C/C++程序员应聘常见面试题深入剖析(2)