c语言实现两个数相加1~1000000以内数的相加和,代码出错!有没有大神指教

第一部分:基本概念及其它问答題

1、关键字static的作用是什么

这个简单的问题很少有人能回答完全。在C语言中关键字static有三个明显的作用:

1). 在函数体,一个被声明为静态的變量在这一函数被调用过程中维持其值不变

2). 在模块内(但在函数体外),一个被声明为静态的变量可以被模块内所用函数访问但不能被模块外其它函数访问。它是一个本地的全局变量

3). 在模块内,一个被声明为静态的函数只可被这一模块内的其它函数调用那就是,这個函数被限制在声明它的模块的本地范围内使用

大多数应试者能正确回答第一部分,一部分能正确回答第二部分同是很少的人能懂得苐三部分。这是一个应试者的严重的缺点因为他显然不懂得本地化数

据和代码范围的好处和重要性。

2、“引用”与指针的区别是什么

答 、1) 引用必须被初始化,指针不必

2) 引用初始化以后不能被改变,指针可以改变所指的对象

3) 不存在指向空值的引用,但是存在指向空值嘚指针

指针通过某个指针变量指向一个对象后,对它所指向的变量间接操作程序中使用指针,程序的可读性差;而引用本身就是目标變量的别名对引用的操作就是对目标变量的操作。

流操作符<<和>>、赋值操作符=的返回值、拷贝构造函数的参数、赋值操作符=的参数、其它凊况都推荐使用引用

答:防止该头文件被重复引用


}

版权声明:本文为博主原创文章未经博主允许不得转载。 /m0_/article/details/

Linux环境下C语言中整数类型最长的是long long类型,占8个字节即使如此,其能表示的数仍是有限的如果想要实现更大嘚整数相加或其他运算,就不能只用long long类型或者普通整型我们可以使用字符串来表示整数,可以由我们规定位数这样就可以实现更大的(某种意义上的任意长)整数相加减。在这里我使用字符串实现的是两个任意长整数相加。由于是使用的字符串需要考虑的情况很多。下面我罗列几个需要注意的点:

使用的输入方法不同需要注意的点也不同。若是使用scanf("%s",str)需要考虑字符数组的大小,但使用这个函数有個缺点如果无意输入了空格,由于该函数不读空格检测不出这个错误。我使用的是fgets(str,SIZE,stdin)函数需要注意的是,若是输入的字符串长度(不包括回车)小于SIZE-1则会将回车符读入,需要去掉回车符;若是输入的字符串长度(不包括回车)等于或大于SIZE-1多余的字符(包括回车)不會读入,但是会留在缓冲区输入下一个字符串时,会直接将这些字符读入所以要先清空缓冲区(再用fgets读一下)。

在字符串读取后需偠判断每一个字符是否是数字字符或者'\0',不是的话就要报错

我们进行整数加法是最低位对齐的,从最低位开始计算但是我们输入字符數字后,字符串是从最高位对齐的所以解决的办法可以将两个字符串逆序,计算后将结果逆序回来

进行正常的整数加法不需要我们考慮进位问题,计算机会给我们解决但是使用字符串计算就需要考虑这个问题了,当两个数相加后(这里还要考虑一个问题就是不能直接芓符相加需要减掉一个字符0),大于字符9就要进位,下一位计算时要考虑前一位是否进位过来(当两个字符串不等长时,不等长的蔀分相加不需要减字符0)最后还要考虑最高位的问题如果有进位,长度会加1要处理一下以保证正常输出。

其他的一下细节大家细心一點就行下面是我实现的具体代码:

else //如果两个字符串对应位都不为'\0',结果为两个字符ASCII码值相加并减去字符0的ASCII码值 //检查字符串中有没有非數字字符并去掉回车符 printf("输入的数字中有非数字以外的字符!\n"); //逆序两个字符串,使得表示的数字最低位对齐 //判断两个字符串长短取更长的字苻串的长度作为参数给add函数

有关更多字符串和整数之间的相互转换的知识,希望和大家一起讨论分享

}

1、关键字static的作用是什么

这个简單的问题很少有人能回答完全。在C语言中关键字static有三个明显的作用:

1). 在函数体,一个被声明为静态的变量在这一函数被调用过程中维持其值不变

2). 在模块内(但在函数体外),一个被声明为静态的变量可以被模块内所用函数访问但不能被模块外其它函数访问。它是一个夲地的全局变量

3). 在模块内,一个被声明为静态的函数只可被这一模块内的其它函数调用那就是,这个函数被限制在声明它的模块的本哋范围内使用

2引用与指针的区别是什么?

答 、1) 引用必须被初始化指针不必。

2) 引用初始化以后不能被改变指针可以改变所指的對象。

3) 不存在指向空值的引用但是存在指向空值的指针。

指针通过某个指针变量指向一个对象后对它所指向的变量间接操作。程序中使用指针程序的可读性差;而引用本身就是目标变量的别名,对引用的操作就是对目标变量的操作 

流操作符<<和>>、赋值操作符=的返回值、拷贝构造函数的参数、赋值操作符=的参数、其它情况都推荐使用引用

答:防止该头文件被重复引用。

答:前者是从Standard Library标准库的路径寻找和引用file.h而后者是从当前工作路径搜寻并引用file.h。

5、描述实时系统的基本特性

答 :在特定时间内完成特定的任务实时性与可靠性。

6、全局变量和局部变量在内存中是否有区别如果有,是什么区别

答 :全局变量储存在静态数据区,局部变量在堆栈中

7、什么是平衡二叉树?

答 :左右子树都是平衡二叉树 且左右子树的深度差值的绝对值不大于1

8、堆栈溢出一般是由什么原因导致的?

答 :1.没有回收垃圾资源

 2.层次呔深的递归调用

9、冒泡排序算法的时间复杂度是什么

10、什么函数不能声明为虚函数?

11、队列和栈有什么区别

答:队列先进先出,栈后進先出

13、局部变量能否和全局变量重名

答:能,局部会屏蔽全局要用全局变量,需要使用"::"

局部变量可以与全局变量同名在函数内引鼡这个变量时,会用到同名的局部变量而不会用到全局变量。对于有些编译器而言在同一个函数内可以定义多个同名的局部变量,比洳在两个循环体内都定义一个同名的局部变量而那个局部变量的作用域就在那个循环体内

14、如何引用一个已经定义过的全局变量?

答 、鈳以用引用头文件的方式也可以用extern关键字,如果用引用头文件方式来引用某个在头文件中声明的全局变量假定你将那个变量写错了,那么在编译期间会报错如果你用extern方式引用时,假定你犯了同样的错误那么在编译期间不会报错,而在连接期间报错

15、全局变量可不鈳以定义在可被多个.C文件包含的头文件中?为什么

答 、可以,在不同的C文件中以static形式来声明同名全局变量

可以在不同的C文件中声明同洺的全局变量,前提是其中只能有一个C文件中对此变量赋初值此时连接不会出错。

16、语句for( 1 )有什么问题它是什么意思?

答 、前一个循环一遍再判断后一个判断以后再循环。

18statac 全局变量、局部变量、函数与普通全局变量、局部变量、函数

static全局变量与普通的全局变量有什么区别static局部变量和普通局部变量有什么区别?static函数与普通函数有什么区别

答 、全局变量(外部变量)的说明之前再冠以static 就构成了静态的铨局变量。全局变量本身就是静态存储方式 静态全局变量当然也是静态存储方式。 这两者在存储方式上并无不同这两者的区别虽在于非静态全局变量的作用域是整个源程序, 当一个源程序由多个源文件组成时非静态的全局变量在各个源文件中都是有效的。 而静态全局變量则限制了其作用域 即只在定义该变量的源文件内有效, 在同一源程序的其它源文件中不能使用它由于静态全局变量的作用域局限於一个源文件内,只能为该源文件内的函数公用 因此可以避免在其它源文件中引起错误。

从以上分析可以看出 把局部变量改变为静态變量后是改变了它的存储方式即改变了它的生存期。把全局变量改变为静态变量后是改变了它的作用域 限制了它的使用范围。

static函数与普通函数作用域不同仅在本文件。只在当前源文件中使用的函数应该说明为内部函数(static)内部函数应该在当前源文件中说明和定义。对于可茬当前源文件以外使用的函数应该在一个头文件中说明,要使用这些函数的源文件要包含这个头文件

static全局变量与普通的全局变量有什么區别:static全局变量只初使化一次防止在其他文件单元中被引用;

static局部变量和普通局部变量有什么区别:static局部变量只被初始化一次,下一次依據上一次结果值;

static函数与普通函数有什么区别:static函数在内存中只有一份普通函数在每个被调用中维持一份拷贝

19、程序的内存分配答:一個由c/C++编译的程序占用的内存分为以下几个部分
1、栈区(stack)—由编译器自动分配释放,存放函数的参数值局部变量的值等。其操作方式类姒于数据结构中的栈
2、堆区(heap)—一般由程序员分配释放,若程序员不释放程序结束时可能由OS回收。注意它与数据结构中的堆是两回倳分配方式倒是类似于链表
3、全局区(静态区)(static)—全局变量和静态变量的存储是放在一块的,初始化的全局变量和静态变量在一块區域未初始化的全局变量和未初始化的静态变量在相邻的另一块区域。程序结束后由系统释放
4、文字常量区—常量字符串就是放在这裏的。程序结束后由系统释放
5、程序代码区存放函数体的二进制代码

20、解释堆和栈的区别

stack:由系统自动分配。例如声明在函数中一个局部变量int b;系统自动在栈中为b开辟空间
heap:需要程序员自己申请,并指明大小在cmalloc函数
但是注意p1p2本身是在栈中的。

(2)申请后系统的响应
栈:只要栈的剩余空间大于所申请空间系统将为程序提供内存,否则将报异常提示栈溢出
堆:首先应该知道操作系统有一个记录空闲内存地址的链表,当系统收到程序的申请时
会遍历该链表,寻找第一个空间大于所申请空间的堆结点然后将该结点从空闲结点链表中删除,并将该结点的空间分配给程序另外,对于大多数系统会在这块内存空间中的首地址处记录本次分配的大小,这样代码中的delete语句財能正确的释放本内存空间。另外由于找到的堆结点的大小不一定正好等于申请的大小,系统会自动的将多余的那部分重新放入空闲链表中

栈:在Windows,栈是向低地址扩展的数据结构,是一块连续的内存的区域这句话的意思是栈顶的地址和栈的最大容量是系统预先规定好嘚,在WINDOWS下栈的大小是2M(也有的说是1M,总之是一个编译时就确定的常数)如果申请的空间超过栈的剩余空间时,将提示overflow因此,能从栈獲得的空间较小
堆:堆是向高地址扩展的数据结构,是不连续的内存区域这是由于系统是用链表来存储的空闲内存地址的,自然是不連续的而链表的遍历方向是由低地址向高地址。堆的大小受限于计算机系统中有效的虚拟内存由此可见,堆获得的空间比较灵活也仳较大。

4)申请效率的比较:
:由系统自动分配速度较快。但程序员是无法控制的
:是由new分配的内存,一般速度比较慢而且容易產生内存碎片,不过用起来最方便.
另外,在WINDOWS下最好的方式是用Virtual Alloc分配内存,他不是在堆也不是在栈,而是直接在进程的地址空间中保留一块內存,虽然用起来最不方便但是速度快,也最灵活

5)堆和栈中的存储内容
栈:在函数调用时,第一个进栈的是主函数中后的下一条指令(函数调用语句的下一条可执行语句)的地址然后是函数的各个参数,在大多数的C编译器中参数是由右往左入栈的,然后是函数Φ的局部变量注意静态变量是不入栈的。
当本次函数调用结束后局部变量先出栈,然后是参数最后栈顶指针指向最开始存的地址,吔就是主函数中的下一条指令程序由该点继续运行。
堆:一般是在堆的头部用一个字节存放堆的大小堆中的具体内容由程序员安排。

21.什么是预编译何时需要预编译

答:预编译又称为预处理,是做些代码文本的替换工作。处理#开头的指令,比如拷贝#include包含的文件代码#define宏定义嘚替换,条件编译等,就是为编译做的预备工作的阶段主要处理#开始的预编译指令,预编译指令指示了在程序正式编译前就由编译器进行嘚操作可以放在程序中的任何位置。

c编译系统在对程序进行通常的编译之前先进行预处理。c提供的预处理功能主要有以下三种:1)宏萣义 2)文件包含 3)条件编译

1、 总是使用不经常改动的大型代码体

2、程序由多个模块组成,所有模块都使用一组标准的包含文件和楿同的编译选项在这种情况下,可以将所有包含文件预编译为一个预编译头

22、关键字const是什么含意?

答:我只要一听到被面试者说:const意味着常数我就知道我正在和一个业余者打交道。去年Dan Programming)的每一位读者应该非常熟悉const能做什么和不能做什么.如果你从没有读到那篇文章只要能说出const意味着只读就可以了。尽管这个答案不是完全的答案但我接受它作为一个正确的答案。(如果你想知道更详细的答案仔细读一下Saks的文章吧。)如果应试者能正确回答这个问题我将问他一个附加的问题:下面的声明都是什么意思?

前两个的作用是一样a是一个常整型数。第三个意味着a是一个指向常整型数的指针(也就是整型数是不可修改的,但指针可以)第四个意思a是一个指向整型数的常指针(也就是说,指针指向的整型数是可以修改的但指针是不可修改的)。最后一个意味着a是一个指向常整型数的常指针(也僦是说指针指向的整型数是不可修改的,同时指针也是不可修改的)如果应试者能正确回答这些问题,那么他就给我留下了一个好印潒顺带提一句,也许你可能会问即使不用关键字 const,也还是能很容易写出功能正确的程序那么我为什么还要如此看重关键字const呢?我也洳下的几下理由:

关键字const的作用是为给读你代码的人传达非常有用的信息实际上,声明一个参数为常量是为了告诉了用户这个参数的应鼡目的如果你曾花很多时间清理其它人留下的垃圾,你就会很快学会感谢这点多余的信息(当然,懂得用const的程序员很少会留下的垃圾讓别人来清理的)

2). 通过给优化器一些附加的信息,使用关键字const也许能产生更紧凑的代码

3). 合理地使用关键字const可以使编译器很自然地保护那些不希望被改变的参数,防止其被无意的代码修改简而言之,这样可以减少bug的出现

23、关键字volatile有什么含意 并给出三个不同的例子

答:┅个定义为volatile的变量是说这变量可能会被意想不到地改变,这样编译器就不会去假设这个变量的值了。精确地说就是优化器在用到这个變量时必须每次都小心地重新读取这个变量的值,而不是使用保存在寄存器里的备份下面是volatile变量的几个例子:

1). 并行设备的硬件寄存器(洳:状态寄存器)

3). 多线程应用中被几个任务共享的变量

回答不出这个问题的人是不会被雇佣的。我认为这是区分C程序员和嵌入式系统程序員的最基本的问题嵌入式系统程序员经常同硬件、中断、RTOS等等打交道,所用这些都要求volatile变量不懂得volatile内容将会带来灾难。

假设被面试者囸确地回答了这是问题(嗯怀疑这否会是这样),我将稍微深究一下看一下这家伙是不是直正懂得volatile完全的重要性。

1). 一个参数既可以是const還可以是volatile吗解释为什么。

2). 一个指针可以是volatile 吗解释为什么。

3). 下面的函数有什么错误:

1). 是的一个例子是只读的状态寄存器。它是volatile因为它鈳能被意想不到地改变它是const因为程序不应该试图去修改它。

2). 是的尽管这并不很常见。一个例子是当一个中服务子程序修该一个指向一個buffer的指针时

3). 这段代码的有个恶作剧。这段代码的目的是用来返指针*ptr指向值的平方但是,由于*ptr指向一个volatile型参数编译器将产生类似下面嘚代码:

由于*ptr的值可能被意想不到地该变,因此ab可能是不同的结果,这段代码可能返不是你所期望的平方值!正确的代码如下:

24、三種基本的数据模型

答:按照数据结构类型的不同将数据模型划分为层次模型、网状模型和关系模型。

25、结构与联合有和区别

答:(1). 结构囷联合都是由多个不同的数据类型成员组成, 但在任何同一时刻, 联合中只存放了一个被选中的成员(所有成员共用一块地址空间, 而结构的所有成员都存在(不同成员的存放地址不同)。 
 (2). 对于联合的不同成员赋值, 将会对其它成员重写原来成员的值就不存在了, 而对于结构的不同荿员赋值是互不影响的

26、描述内存分配方式以及它们的区别?

答:1 从静态存储区域分配内存在程序编译的时候就已经分配好,这块内存茬程序的整个运行期间都存在例如全局变量,static 变量
2 在栈上创建。在执行函数时函数内局部变量的存储单元都可以在栈上创建,函數执行结束时这些存储单元自动被释放栈内存分配运算内置于处理器的指令集。
3 从堆上分配亦称动态内存分配。程序在运行的时候鼡malloc new 申请任意多少的内存程序员自己负责在何时用free delete 释放内存。动态内存的生存期由程序员决定使用非常灵活,但问题也最多

答:Const作鼡:定义常量、修饰函数参数、修饰函数返回值三个作用被Const修饰的东西都受到强制保护,可以预防意外的变动能提高程序的健壮性。

1 const 常量有数据类型而宏常量没有数据类型。编译器可以对前者进行类型安全检查而对后者只进行字符替换,没有类型安全检查并且茬字符替换可能会产生意料不到的错误。

28、简述数组与指针的区别

29、分别写出BOOL,int,float,指针类型的变量a 的比较语句。

30、如何判断一段程序是由C 编译程序还是由C++编译程序编译的

31、论述含参数的宏与函数的优缺点

32、用两个栈实现一个队列的功能?要求给出算法和思路!

答 、設2个栈为A,B, 一开始均为空.

(1)判断栈B是否为空;

(2)如果不为空则将栈A中所有元素依次pop出并push到栈B

(3)将栈B的栈顶元素pop出;

这样实现的队列入队和出队嘚平摊复杂度都还是O(1), 比上面的几种方法要好

33、嵌入式系统中经常要用到无限循环,你怎么样用C编写死循环呢

答:这个问题用几个解决方案。我首选的方案是:

一些程序员更喜欢如下方案:

这个实现方式让我为难因为这个语法没有确切表达到底怎么回事。如果一个应试者給出这个作为方案我将用这个作为一个机会去探究他们这样做的

基本原理。如果他们的基本答案是:我被教着这样做但从没有想到過为什么。这会给我留下一个坏印象

第三个方案是用 goto

应试者如给出上面的方案,这说明或者他是一个汇编语言程序员(这也许是好事)或者他是一个想进入新领域的BASIC/FORTRAN程序员

答: 嵌入式系统总是要用户对变量或寄存器进行位操作。给定一个整型变量a写两段代码,第一個设置abit 3第二个清除a bit 3。在以上两个操作中要保持其它位不变。
对这个问题有三种基本的反应
1)不知道如何下手该被面者从没做过任哬嵌入式系统的工作。
2) bit fields(字段)Bit fields是被扔到C语言死角的东西,它保证你的代码在不同编译器之间是不可移植的同时也保证了的你的代碼是不可重用的。我最近不幸看到 Infineon为其较复杂的通信芯片写的驱动程序它用到了bit fields因此完全对我无用,因为我的编译器用其它的方式来实現bit fields的从道德讲:永远不要让一个非嵌入式的家伙粘实际硬件的边。
3) #defines bit masks 操作这是一个有极高可移植性的方法,是应该被用到的方法朂佳的解决方案如下:

答: 中断是嵌入式系统中重要的组成部分,这导致了很多编译开发商提供一种扩展让标准C支持中断具代表事实昰,产生了一个新的关键字 __interrupt下面的代码就使用了__interrupt关键字去定义了一个中断服务子程序(ISR),请评论一下这段代码的

在许多的处理器/编译器Φ,浮点一般都是不可重入的有些处理器/编译器需要让额处的寄存器入栈,有些处理器/编译器就是不允许在ISR中做浮点运算此外,ISR应该昰短而有效率的在ISR中做浮点运算是不明智的。
4) 与第三点一脉相承printf()经常有重入和性能上的问题。   如果你丢掉了第三和第四点我不会太為难你的。不用说如果你能得到后两点,那么你的被雇用前景越来越光明了

答:尽管不像非嵌入式计算机那么常见,嵌入式系统还是囿从堆(heap)中动态分配内存的过程的那么嵌入式系统中,动态分配内存可能发生的问题是什么
这里,我期望应试者能提到内存碎片誶片收集的问题,变量的持行时间等等这个主题已经在ESP杂志中被广泛地讨论过了(主要是 P.J. Plauger, pointer"。我用这个来开始讨论这样的一问题看看被媔试者是否想到库例程这样做是正确。得到正确的答案固然重要但解决问题的方法和你做决定的基本原理更重要些。

答:Typedef C语言中频繁鼡以声明一个已经存在的数据类型的同义字也可以用预处理器做类似的事。例如思考一下下面的例子:
   以上两种情况的意图都是要定義dPS tPS 作为一个指向结构s指针。哪种方法更好呢(如果有的话)为什么?
   这是一个非常微妙的问题任何人答对这个问题(正当的原因)昰应当被恭喜的。答案是:typedef更好思考下面的例子:
    上面的代码定义p1为一个指向结构的指,p2为一个实际的结构这也许不是你想要的。第②个例子正确地定义了p3 p4 两个指针

39、用变量a给出下面的定义

40、解释局部变量、全局变量和静态变量的含义。

答:局部变量:在一个函数內部定义的变量是内部变量它只在本函数范围内有效,也就是说只有在本函数内才能使用它们在此函数以外时不能使用这些变量的,咜们称为局部变量;说明:1.主函数main中定义的变量也只在主函数中有效而不因为在主函数中定义而在整个文件或程序中有效
2.不同函数中可鉯使用名字相同的变量,它们代表不同的对象互不干扰3.形式参数也使局部变量4.在一个函数内部,可以在复合语句中定义变量这些变量呮在本符合语句中有效
全局变量:在函数外定义的变量是外部变量,外部变量是全局变量全局变量可以为本文件中其它函数所共用,它嘚有效范围从定义变量的位置开始到本源文件结束;说明:1.设全局变量的作用:增加了函数间数据联系的渠道
2.建议不再必要的时候不要使鼡全局变量因为a.全局变量在程序的全部执行过程中都占用存储单元;

b.它使函数的通用性降低了c.使用全局变量过多,会降低程序的清晰性3.洳果外部变量在文件开头定义则在整个文件范围内都可以使用该外部变量,如果不再文件开头定义按上面规定作用范围只限于定义点箌文件终了。如果在定义点之前的函数想引用该外部变量则应该在该函数中用关键字extern作外部变量说明
4.如果在同一个源文件中,外部变量與局部变量同名则在局部变量的作用范围内,外部变量不起作用;静态变量:在程序运行期间分配固定的存储空间的变量叫做静态变量

41、写一个标准

已知一个数组table,用一个宏定义求出数据的元素个数

B.c两个c文件中使用了两个相同名字的static变量,编译的时候会不会有問题?这两个static变量会保存到哪里(栈还是堆或者其他的)?

答:static的全局变量,表明这个变量仅在本模块中有意义不会影响其他模块。

他们都放在数据区但是编译器对他们的命名是不同的。

如果要使变量在其他模块也有意义的话需要使用extern关键字。

43、一个单向链表不知道头節点,一个指针指向其中的一个节点,问如何删除这个指针指向的节点

答:将这个指针指向的next节点值copy到本节点,将next指向next->next,并随后删除原next指向嘚节点

44.C语言中各进制表示法

\0oo  八进制值(o表示一个八进制数字)

\xhh  十六进制值(h表示一个十六进制数字)

16进制0x234这样的(如24就是0x018,凡是以0X0x开頭的数字序列) 8进制01111这样的(凡是16进制0x234这样的(如24就是0x018凡是以0X0x开头的数字序列) 8进制01111这样的(凡是以0开头的数字序列)以0开头的数字序列)


">6"。原因是当表达式中存在有符号类型和无符号类型时所有的操作数都自动转换为无符号类型因此-20变成了一个非常大的正整数,所鉯该表达式计算出的结果大于6这一点对于应当频繁用到无符号数据类型的嵌入式系统来说是丰常重要的。如果你答错了这个问题你也僦到了得不到这份工作的边缘。
对于一个int型不是16位的处理器为说上面的代码是不正确的。应编写如下:
    这一问题真正能揭露出应试者是否懂得处理器字长的重要性在我的经验里,好的嵌入式程序员非常准确地明白硬件的细节和它的局限然而PC机程序往往把硬件作为一个無法避免的烦恼。

3 C语言同意一些令人震惊的结构,下面的结构是合法的吗如果是它做些什么?int a = 5, b = 7, c;
因此上面的代码被处理成:
如果你知道答案,或猜出正确答案做得好。如果你不知道答案我也不把这个当作问题。我发现这个问题的最大好处是这是一个关于代码编写风格代码的可读性,代码的可修改性的好的话题

4、设有以下说明和定义:

答 、结果是:52DATE是一个union, 变量公用空间. 里面最大的变量类型是int[5], 占用20個字节. 所以它的大小是20

5、请写出下列代码的输出内容

我总结:不管a的自加还是自减在等号的那一边最终a自身的值也会改变

6、写出下列代碼的输出内容


7、请找出下面代码中的所以错误

说明:以下代码是把一个字符串倒序,如“abcd”倒序后变为“dcba”

free(dest);// 使用完应当释放空间,以免慥成内存汇泄露

8、请问下面程序有什么错误?

答案:把循环语句内外换一下

//对于多重循环一定是内循环数大于等于外循环数

9、请问下面程序會出现什么情况?

//字符型应该是到255再加的话就溢出了,我觉得会出问题可能就死循环了

char const * p//指向常量的指针,指向的常量值不可以改

解答:str1,str2,str3,str4是数组变量它们有各自的内存空间;

12、以下代码中的两个sizeof用法有问题吗?

答:函数内的sizeof有问题根据语法,sizeof如用于数组只能测出静態数组的大小,无法检测动态分配的或外部数组大小函数外的str是一个静态定义的数组,因此其大小为6函数内的str实际只是一个指向字符串的指针,没有任何额外的与数组相关的信息因此sizeof作用于上只将其当指针看,一个指针为4个字节因此返回4

13、写出输出结果红色标記

&a+1不是首地址+1系统会认为加一个a数组的偏移,是偏移了一个数组的大小(本例是5int

而指针加1要根据指针类型加上一定的值

不同类型的指针+1之后增加的大小不同

a,&a的地址是一样的,但意思不一样a是数组首地址,也就是a[0]的地址&a是对象(数组)首地址,a+1是数组下一元素嘚地址即a[1],&a+1是下一个对象的地址,即a[5].

14、请问以下代码有什么问题:

没有为str分配内存空间将会发生异常

问题出在将一个字符串复制进一个芓符变量指针所指地址。虽然可以正确输出结果但因为越界进行内在读写而导致程序崩溃。

"AAA"是字符串常量s是指针,指向这个字符串常量所以声明s的时候就有问题。

然后又因为是常量所以对是s[0]的赋值操作是不合法的。

15、有以下表达式:红色标记

请问下列表达式哪些会被编译器禁止为什么?

*c 这是个什么东东禁止

16、交换两个变量的值,不使用第三个变量

有两种解法, 一种用算术算法, 一种用^(异或)

17、丅面的程序会出现什么结果

18、下面的语句会出现什么结果?

答案:长度不一样会造成非法的OS,应该改为char szstr[11]

答:其中ptr为同一个指针

20、问函數既然不会被其它函数调用为什么要返回1

答:mianc标准认为0表示成功,非0表示错误具体的值是某中具体出错信息

21、对绝对地址0x100000赋值苴想让程序跳转到绝对地址是0x100000去执行

首先要将0x100000强制转换成函数指针,:

typedef可以看得更直观些:

22、输出多少?并分析过程

为-11但输出的是uint。所鉯输出

第二题c0x10,输出的是int,最高位为1是负数,所以它的值就是0x00的补码就是128所以输出-128

这两道题都是在考察二进制向intuint转换时的最高位处理

补码:例如12模的系统中,加8和减4效果是一样的因此凡是减4运算,都可以用加8来代替对而言,84互为补数实际上以12模的系统中,111102937566都有这个特性共同的特点是两者相加等于模。在以12模的系统中加8和减4效果是一样的,因此凡是减4运算都可以用加8来代替。 0000-b)是什么恰好就是b的补码负数的补码等于其反码+1 定理:减去一个数就是加上它的补码,结果一样所以解決了负数的计算。有了补码的概念所有的加减都可以用加法来计算了。对于计算机而言方便了许多

假设模为88位)的操作系统即它能表示256个数,数的表示范围为-128----+127(共256注意别忘了0),正负数各占一半-128------+127但对于-128----

23、分析下面的程序:

问输出结果是什么?希望大家能说说原因先谢谢了

free 只是释放的str指向的内存空间,它本身的值还是存在的.

所以free之后,有一个好的习惯就是将str=NULL.

此时str指向空间的内存已被回收,如果输出语呴之前还存在分配空间的操作的话,这段存储空间是可能被重新分配给其他变量的,

尽管这段程序确实是存在大大的问题(上面各位已经说得佷清楚了)但是通常会打印出world来。

这是因为进程中的内存管理一般不是由操作系统完成的,而是由库函数自己完成的

当你malloc一块内存嘚时候,管理库向操作系统申请一块空间(可能会比你申请的大一些)然后在这块空间中记录一些管理信息(一般是在你申请的内存前媔一点),并将可用内存的地址返回但是释放内存的时候,管理库通常都不会将内存还给操作系统因此你是可以继续访问这块地址的,只不过。。。。楼上都说过了最好别这么干。

sizeof()和初不初始化没有关系;

27、下面的函数实现在一个数上加一个数,有什么错誤请改正。

当你第二次调用时得不到正确的结果难道你写个函数就是为了调用一次?问题就出在 static//static会把值保存下来

28、给出下面程序的答案红色标记//好像有问题

所以最后一步:显示的是这4个字节的前5位,和之后的2位

因为int是有正负之分  所以:答案是-16和1

知噵了这是统计9999的二进制数值中有多少个1的函数且有

9×1024中含有1的个数为2

512中含有1的个数为1

256中含有1的个数为1

15中含有1的个数为4

故共有1的個数为8,结果为8

用这种方法来求1的个数是很效率很高的。

不必去一个一个地移位循环次数最少。

30、分析:红色标记

c为有符合数時, c = 100, 最高1为表示c为负数负数在计算机用补码表示,所以c = -4;同理

31、下面这个程序执行后会有什么错误或者效果:

解答:死循环加数组越界访问(C/C++鈈进行数组越界检查)

其二.i循环到255,循环内执行:

在第二个结构中为保证num按四个字节对齐,char后必须留出3字节的空间;同时为保证整个结構的自然对齐(这里是4字节对齐)在x后还要补齐2个字节,这样就是12字节

理论上是这样的,首先是i在相对0的位置占8位一个字节,然后j就在相对一个字节的位置,由于一个位置的字节数是4位的倍数因此不用对齐,就放在那里了然后是a,要在3位的倍数关系的位置上洇此要移一位,在15位的位置上放下目前总共是18位,折算过来是2字节2位的样子由于double8字节的,因此要在相对0要是8个字节的位置上放下洇此从18位开始到8个字节之间的位置被忽略,直接放在8字节的位置了因此,总共是16字节特殊注意

第二个最后会对照是不是结构体内最大數据的倍数,不是的话会补成是最大数据的倍数

希望各位达人给出答案和原因,谢谢拉

解答:假设在32CPU

37、写出程序运行结果

// static会保存仩次结果,记住这一点剩下的自己写

// b定义后就没有赋值

解释:指针一次移动一个int但计数为1

RetMenory执行完毕,p资源被回收指向未知地址。返回哋址str的内容应是不可预测的, 打印的应该是str的地址

t.b11,输出就是-1

3个都是有符号数int

这是位扩展问题 //查一下

41、对下面程序进行分析

解答:如果面试者指出字符数组str1不能在数组内结束可以给3分;如果面试者指出strcpy(string, str1)调用使得从str1内存起复制到string内存起所复制的字节数具有不确定性可鉯给7分,在此基础上指出库函数strcpy工作方式的给10分;

*s2)他的工作原理是扫描s2指向的内存,逐个字符付到s1所指向的内存直到碰到'\0',因为str1结尾没囿'\0',所以具有不确定性不知道他后面还会付什么东东。

*(++ptr));从后往前执行指针先++,指向8然后输出8,紧接着再输出8

43、分析下面的代码:

这個简单的面试题目,我选输出 no(对比的应该是指针地址吧),可在VCYES

lz的呢是一个常量字符串。位于静态存储区它在程序生命期内恒定不变。如果编译器优化的话会有可能ab同时指向同一个hello的。则地址相同如果编译器没有优化,那么就是两个不同的地址则不同

这种方式和编譯器中得函数调用关系相关即先后入栈顺序。不过不同编译器得处理不同也是因为C标准中对这种方式说明为未定义,所以各个编译器厂商都有自己得理解所以最后产生得结果完全不同。因为这样所以遇见这种函数,我们首先要考虑我们得编译器会如何处理这样得函数其次看函数得调用方式,不同得调用方式可能产生不同得结果。最后是看编译器优化

1、读文件file1.txt的内容(例如):

2、输出为一个给萣整数的所有组合

5=1+45=2+3(相加的数不能重复)

4、写一段程序,找出数组中第k大小的数输出数所在的位置。例如{24347}中第一大的数是7,位置在4第二大、第三大的数都是4,位置在13随便输出哪一个均可函数接口为:int

要求算法复杂度不能是O(n^2

可以先用快速排序进行排序,其中用另外一个进行地址查找

代码如下在VC++6.0运行通过。给分吧^-^

6、用递归算法判断数组a[N]是否为一个递增数组

递归的方法,记录当前最大嘚并且判断当前的是否比这个还大,大则继续否则返回false结束:

7、单连表的建立,把'a'--'z'26个字母插入到连表中并且倒叙,还要打印!

8、请列举一个软件中时间换空间或者空间换时间的例子

10、不用库函数,C语言实现将一整型数字转化为字符串

11、求组合数: 求n个数(1....n)中k个数嘚组合....

12、用指针的方法,将字符串“ABCD1234efgh”前后对调显示

13、有一分数序列:1/2,1/4,1/6,1/8……用函数调用的方法,求此数列前20项的和

14、有一个数组a[1000]存放0--1000;要求每隔二个数删掉一个数到末尾时循环至开头继续进行,求最后一个被删掉的数的原始下标位置

做是做对了,没有抄搞比较乱

做是莋对了,没有抄搞比较乱

17、已知一个单向链表的头,请写出删除其某一个结点的算法要求,先找到此结点然后删除。

18、有1,2,....一直到n的無序数组,求排序算法,并且要求时间复杂度为O(n),空间复杂度O(1),使用交换,而且一次只能交换两个数.(华为)

19、写出程序把一个链表中的接点顺序倒排

20、写出程序删除链表中的所有接点

21、两个字符串s,t;t字符串插入到s字符串中,s字符串有足够的空间存放t字符串

22、写一个函数功能:完荿内存之间的拷贝

23、公司考试这种题目主要考你编写的代码是否考虑到各种情况,是否安全(不会溢出)

1、参数是指针检查指针是否囿效

2、检查复制的源目标和目的地是否为同一个,若为同一个则直接跳出

4、安全检查,是否会溢出

memcpy拷贝一块内存内存的大小你告訴它

strcpy是字符串拷贝,遇到'\0'结束

24、两个字符串s,t;t字符串插入到s字符串中,s字符串有足够的空间存放t字符串

25、在一个字符串中找到可能的最長的子字符串且该字符串是由同一字符组成的。

26、在给定的内存区域搜索给定的字符并返回该字符所在位置索引值。

27、给定字符串AB,輸出AB中的最大公共子串

28、写一个函数比较两个字符串str1str2的大小,若相等返回0str1大于

29、求1000!的未尾有几个0(用素数相乘的方法来做,洳72=2*2*2*3*3;

求出1->1000,能被5整除的数的个数n1,能被25整除的数的个数n2,能被125整除的数的个数n3,

能被625整除的数的个数n4.

30、有双向循环链表结点定义为: 

有两个双向循环链表AB,知道其头指针为:pHeadA,pHeadB请写一函数将两链表中data值相同的结点删除

32、编程实现:把十进制数(long)分别以二进制和十六进制形式输出,不能使用printf系列库函数

 *x,y):第一个元素的坐标

34、斐波拉契数列递归实现的方法如下:

请问如何不使用递归,来实现上述函数

现在大哆数系统都是将低字位放在前面,而结构体中位域的申明一般是先声明高位

如果先申明的在低位则:

2、原题跟位域的存储空间分配有关,到底是从低字节分配还是从高字节分配从Dev C++VC7.1上看,都是从低字节开始分配并且连续分配,中间不空不像谭的书那样会留空位

3、原題跟编译器有关,编译器在未用堆栈空间的默认值分配上有所不同Dev C++未用空间分配为

注:PC一般采用little-endian,即高高低低但在网络传输上,一般采用big-endian即高低低高,华为是做网络的所以可能考虑big-endian模式,这样输出结果可能为4

35、判断一个字符串是不是回文  abcba从左从右都都是一样的叫回攵

nn个人围坐一圈约定编号为k1<=k<=n)的人从1开始报数,数到m 的那个人出列它的下一位又从1开始报数,数到m的那个人又出列依次类推,矗到所有人出列为止由此产生一个出队编号的序列。

37、已知strcpy函数的原型是:

*转换为bool即是类型隐式转换这种功能虽然灵活,但更多的是導致出错概率增大和维护成本升高所以C++专门增加了booltruefalse三个关键字以提供更安全的条件表达式。

    (C)检查指针的有效性时使用((strDest==0)||(strSrc==0))说明答题者鈈知道使用常量的好处。直接使用字面常量(如本例中的0)会减少程序的可维护性0虽然简单,但程序中可能出现很多处对指针的检查萬一出现笔误,编译器不能发现生成的程序内含逻辑错误,很难排除而使用NULL代替0,如果出现拼写错误编译器就会检查出来。

    (A)return new string("Invalid argument(s)");说明答题者根本不知道返回值的用途,并且他对内存泄漏也没有警惕心从函数中返回函数体内分配的内存是十分危险的做法,他把释放内存嘚义务抛给不知情的调用者绝大多数情况下,调用者不会释放内存这导致内存泄漏。

    (B)return 0;说明答题者没有掌握异常机制。调用者有可能莣记检查返回值调用者还可能无法检查返回值(见后面的链式表达式)。妄想让返回值肩负返回正确值和异常值的双重功能其结果往往是两种功能都失效。应该以抛出异常来代替返回值这样可以减轻调用者的负担、使错误不会被忽略、增强程序的可维护性。

*strDest++=*strSrc++;说明答題者对边界条件的检查不力。循环体结束后strDest字符串的末尾没有正确地加上'\0'

有些信息在存储时并不需要占用一个完整的字节, 而只需占几个或一个二进制位例如在存放一个开关量时,只有01 两种状态 用一位二进位即可。为了节省存储空间并使处理简便,C语言又提供了一种数据结构称为位域位段。所谓位域是把一个字节中的二进位划分为几个不同的区域 并说明每个区域的位数。每个域有一个域名允许在程序中按域名进行操作。 这样就可以把几个不同的对象用一个字节的二进制位域来表示一、位域的定义和位域变量的说明位域定义与结构定义相仿,其形式为:     

位域变量的说明与结构变量说明的方式相同 可采用先定义后说明,同时定义说明戓者直接说明这三种方式例如:     

说明databs变量,共占两个字节其中位域a8位,位域b2位位域c6位。对于位域的定义尚有以下几点说明:

1. 一个位域必须存储在同一个字节中不能跨两个字节。如一个字节所剩空间不够存放另一位域时应从下一单元起存放该位域。也可以囿意使某位域从下一单元开始例如:     

在这个位域定义中,a占第一字节的4位后4位填0表示不使用,b从第二字节开始占用4位,c占用4

2. 由於位域不允许跨两个字节,因此位域的长度不能大于一个字节的长度也就是说不能超过8位二进位。    

3. 位域可以无位域名这时它只用来作填充或调整位置。无名的位域是不能使用的例如:     

从以上分析可以看出,位域在本质上就是一种结构类型 不过其成员是按二进位分配嘚。    

二、位域的使用位域的使用和结构成员的使用相同其一般形式为: 位域变量名?位域名 位域允许用各种格式输出。    

搞错了,是指针类型不同,

&arr; //得到的是指向第一维为100的数组的指针

编译预处理命令一定有#号吗

程序设计语言的预处理的概念:在编译之前进行的处理。 C语言的预處理主要有三个方面的内容: 1.; 2.文件包含; 3. 预处理命令以符号"#"开头

在程序中凡是以#号开始的都是预处理命令;宏替换不占用运行时间,只占鼡编译时间;宏定义后面是没有;好的  如#define pi 3.1415;错的  有分号


}

我要回帖

更多关于 c语言实现两个数相加 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信