C&C++面试题汇总(9)
p=0x1000000; p+0x200=____; (Ulong)p+0x200=____; (char*)p+0x200=____;
希望各位达人给出答案和原因,谢谢拉 解答:假设在32位CPU上, sizeof(long) = 4 bytes sizeof(char *) = 4 bytes
sizeof(short int) = sizeof(short) = 2 bytes sizeof(char) = 1 bytes 由于是4字节对齐,
sizeof(struct BBB) = sizeof(*p)
= 4 + 4 + 2 + 1 + 1/*补齐*/ + 2*5 + 2/*补齐*/ = 24 bytes (经Dev-C++验证)
p=0x1000000; p+0x200=____;
= 0x1000000 + 0x200*24 (Ulong)p+0x200=____; = 0x1000000 + 0x200 (char*)p+0x200=____; = 0x1000000 + 0x200*4 你可以参考一下指针运算的细节
写一段程序,找出数组中第k大小的数,输出数所在的位置。例如{2,4,3,4,7}中,第一大的数是7,位置在4。第二大、第三大的数都是4,位置在1、3随便输出哪一个均可。函数接口为:int find_orderk(const int* narry,const int n,const int k) 要求算法复杂度不能是O(n^2) 谢谢!
可以先用快速排序进行排序,其中用另外一个进行地址查找 代码如下,在VC++6.0运行通过。给分吧^-^ //快速排序
#i nclude
intPartition (int*L,intlow,int high) {
inttemp = L[low]; intpt = L[low]; while (low < high) {
while (low < high && L[high] >= pt) --high;
L[low] = L[high];
while (low < high && L[low] <= pt) ++low;
L[low] = temp; }
L[low] = temp; returnlow;
}
voidQSort (int*L,intlow,int high) {
if (low < high) {
intpl = Partition (L,low,high); QSort (L,low,pl - 1); QSort (L,pl + 1,high); } }
intmain () {
intnarry[100],addr[100]; intsum = 1,t;
cout << \cin >> t; while (t != -1) {
narry[sum] = t; addr[sum - 1] = t; sum++; cin >> t; } sum -= 1;
QSort (narry,1,sum);
for (int i = 1; i <= sum;i++) cout << narry[i] << '\\t'; cout << endl; intk;
cout << \cin >> k; intaa = 1; intkk = 0; for (;;) {
if (aa == k) break;
if (narry[kk] != narry[kk + 1]) { aa += 1; kk++; } }
cout << \cout << \for (i = 0;i < sum;i++) {
if (addr[i] == narry[sum - kk]) cout << i << '\\t'; }
return0; } 1、找错 Void test1() {
char string[10];
char* str1=\
strcpy(string, str1);// 溢出,应该包括一个存放'\\0'的字符string[11] }
Void test2() {
char string[10], str1[10]; for(I=0; I<10;I++) {
str1[i] ='a'; }
strcpy(string, str1);// I,i没有声明。 }
Void test3(char* str1) {
char string[10];
if(strlen(str1)<=10)// 改成<10,字符溢出,将strlen改为sizeof也可以
{
strcpy(string, str1); } } 2.
void g(int**); int main() {
int line[10],i;
int *p=line; //p是地址的地址 for (i=0;i<10;i++) { *p=i;
g(&p);//数组对应的值加1 }
for(i=0;i<10;i++) printf(\return 0; }
void g(int**p) { (**p)++; (*p)++;// 无效 } 输出: 1 2 3 4 5 6 7 8 9 10
3. 写出程序运行结果 int sum(int a) {
auto int c=0; static int b=3; c+=1; b+=2;
return(a+b+c); }
void main() { int I; int a=2;
for(I=0;I<5;I++) {
printf(\} }
// static会保存上次结果,记住这一点,剩下的自己写 输出:8,10,12,14,16, 4.
int func(int a) { int b; switch(a) {
case 1: 30; case 2: 20; case 3: 16; default: 0 }
return b; }
则func(1)=?
// b定义后就没有赋值。 5: int a[3];
a[0]=0; a[1]=1; a[2]=2; int *p, *q; p=a; q=&a[2]; 则a[q-p]=a[2]
解释:指针一次移动一个int但计数为1
…… 此处隐藏:342字,全部文档内容请下载后查看。喜欢就下载吧 ……
相关推荐:
- [高等教育]公司协助某村精准扶贫工作总结.doc
- [高等教育]高二生物知识点总结(全)
- [高等教育]苏教版数学三年级下册《解决问题的策略
- [高等教育]仪器分析课程学习心得
- [高等教育]2017年五邑大学数学与计算科学学院333
- [高等教育]人教版七年级下册语文第四单元测试题(
- [高等教育]2018年秋七年级英语上册Unit7Howmuchar
- [高等教育]2017年八年级下数学教学工作小结
- [高等教育]湖南省怀化市2019届高三统一模拟考试(
- [高等教育]四年级下册科学_基础训练及答案教材
- [高等教育]城郊煤矿西风井管路伸缩器更换施工安全
- [高等教育]昆八中20182019学年度上学期期末考试
- [高等教育]项目部各类人员任命书
- [高等教育]上市公司经营水务产业的模式
- [高等教育]人教版高二化学第一学期第三章水溶液中
- [高等教育]【中考物理第一轮复习资料】四.压强与
- [高等教育]金坑水电站报废改建工程机电设备更新改
- [高等教育]高中生物教学工作计划简易版
- [高等教育]2017年西华大学攀枝花学院(联合办学)44
- [高等教育]最新整理超短爆笑英文小笑话大全
- 优秀教师继续教育学习心得体会
- 阳历到阴历的转换
- 留守儿童教育案例分析
- 华师17春秋学期《玩教具制作与环境布置
- 测速传感器新型安装装置的现场应用
- 人教版小学数学三年级下册第四单元
- 创业个人意向书
- 山东省潍坊市2012年高考仿真试题(三)
- [恒心][好卷速递]四川省成都外国语学校
- 多少人错把好转反应当成了病情加重处理
- 中外广播电视史复习资料整理
- 江苏省扬州市江都区宜陵镇中学2014-201
- 工程造价专业毕业实习报告
- 广西师范学院心理与教育统计
- aympkrq基于 - asp的博客网站设计与开
- 建筑业外出经营相关流程操作(营改增后
- 人治 德治 法治
- [精华篇]常识判断专项训练题库
- 中国共产党为什么要实行民主集中
- 小学数学第三册第一单元试卷(A、B、C




