当前位置: 首页 > news >正文

郑州网站设计费用网站维护工作内容

郑州网站设计费用,网站维护工作内容,网站建设公司找哪里,邯郸求职信息网前言:每日一练系列,每一期都包含5道选择题,2道编程题,博主会尽可能详细地进行讲解,令初学者也能听的清晰。每日一练系列会持续更新,暑假时三天之内必有一更,到了开学之后,将看学业情…

前言:
每日一练系列,每一期都包含5道选择题,2道编程题,博主会尽可能详细地进行讲解,令初学者也能听的清晰。每日一练系列会持续更新,暑假时三天之内必有一更,到了开学之后,将看学业情况更新。

五道选择题:

1、程序运行的结果是() 

#define ADD(x) x+x
#include<stdio.h>
int main()
{int m = 1, n = 2, k = 3;int sum = ADD(m + n) * k;printf("sum = %d", sum);
}

A、 sum=9 B、 sum=10 C、 sum=12 D、 sum=18

解析:考察你对宏定义的理解。宏定义在预处理阶段就会被处理,也就是它走不到编译的阶段它就会被执行,因此我们可以粗略地把宏定义当作是一种替换。

比方说#define abc 5,那么abc*6,就可以直接看作5*6,不需要管其他运算符,你先替换完再说。这道题将ADD(x)宏定义为x+x,因此sum=1+2+1+2*3,不用管别的,你就先替换,所以sum=10,答案选B

2、以下程序的输出的结果是()

#include<stdio.h>
void incre()
{static int x = 1;x *= x + 1;printf("%d ", x);
}
int main()
{int i;for (i = 1; i <= 2; i++) incre();
}

A、 3 3 B、 2 2 C、 2 6 D、 2 5

解析:观察代码构成发现,代码由一个main函数和一个incre函数构成,而main函数的主要作用就是调用了两次incre函数进行对应地操作。所以关键在incre,incre函数首先定义了一个x并将它初始化为1,但特别地是,这个x被static所修饰,因此,这个x的储存是放在静态区中的,故x是不会再被重定义,它在程序运行的一开始就会被定义且生命周期一直到程序结束。

由于次数少,所以直接进行代入,第一次进入incre(),x*=x+1,令x=2,故打印2,第二次进入,此时x=2,x*=x+1,令x=6,故打印6,因此答案为C

 3、以下程序的输出结果是哪一项()

#include <stdio.h>
int main()
{int a[][3] = { 1,2,3,4,5,6,7,8,9,10,11,12 }, * p[4], i;for (i = 0; i < 4; i++)p[i] = &a[i][3];printf("%d\n", p[2][2]);
}

A、 输出项不合法 B、6   C、8 D、12

解析:观察代码可以发现,代码首先定义了一个没有行数只有列数的数组a,接着又定义了一个整型指针数组p和一个控制循环次数的变量i。然后使用循环的方式将一些地址存放到整型指针数组p中,循环次数只有4次,可以直接代入。

当i=0时,将a[0][3]的地址存放到p[0],也就是1行4列的地址,但没有4列,走到2行,所以把2行1列的地址即4的地址存放到p[0]中。

当i=1时,将a[1][3]的地址存放到p[1]中,也就是2行4列的地址,但没有4列,走到3行,将3行1列即7的地址存放到p[1],

当i=2时,将4行1列即10存放到p[2]中,当i=3时,将5行1列存放到p[3]中,也就是将12后面的地址存放到p[3]中,但没有,所以p[3]越界了,因此一旦使用p[3]是有问题的。

最后打印p[2][2],p[2]为10的地址,因此p[2][2]为12,所以打印12,选D

 4、以下关于结构体与共用体的说法,其中正确的是()
A、共用体同一个内存段可以来存放几种不同类型的成员,但在某一时刻只能存放一个成员。
B、结构体变量所占的内存长度等于最长的成员的长度,共用体变量所占内存长度是各成员占的内存长度之和。
C、共用体每个成员分别占有自己的内存单元。
D、结构体类型可以出现在共用体类型的定义中,但共用体类型不能出现在结构体类型定义之中。

解析:共用体指的是由一系列具有相同数据类型或者不同数据类型的数据组成的集合,但它们的数据为互斥关系,因为共用体所有的成员共同使用一份内存空间,当使用成员A的时候,不同于成员A类型的成员B注定不是原来的它。因此A正确。B选项刚好相反,B错误。C选项与概念相悖,大错特错。D选项错误,结构体类型和共用体类型没什么特殊的,本质上都是类型,可以用。综上所述,选A

5、下列程序段的输出结果为()

#include<stdio.h>
int main()
{int arr[] = { 6,7,8,9,10 };int* ptr;ptr = arr;*(ptr + 2) += 2;printf("%d,%d\n", *ptr, *(ptr + 2));
}

 A、8,10   B、6,8    C、7,9    D、6,10

解析:先定义了一个数组arr,并在里面存放了6,7,8,9,10。接着定义了一个指针ptr,并将数组arr的首地址赋值给了ptr,然后*(ptr+2)+=2,令ptr这个地址往后移两个单位,来到8上,令8+=2,使数组arr中存放的6,7,8,9,10变为6,7,10,9,10,所以最后打印ptr时打印出6,打印(ptr+2)打印出10,选D

 编程题1:

 力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

 

提示:由于只需要最后一个单词的长度,所以我们可以根据单词之间有空格的特性来进行遍历,你也可以尝试以下反着计算,也就是先用strlen计算出字符串的长度然后用反着的方式来计算最后一个单词的长度,都是可以的。 

int lengthOfLastWord(char* s) {int i = 0;int count = 0;//计数器,计算最后一个单词的长度int min = 0;//存储器,避免最后一个单词后面有空格,将计数器清零for (i = 0; s[i] != '\0'; i++){if (s[i] == ' '){count = 0;//一旦遇到空格清空计数器}else{count++;min = count;}}if (count == 0)//当计数器为0,不是最后一个单词后面有空格//就是本身就全为空格,本身就全为空格,count也为0,不影响{count = min;}return count;
}

编程题2:

 136. 只出现一次的数字 - 力扣(LeetCode)

快乐的暑假马上就结束了,最后来道简单题,放松一下 

 

提示:两个相同的数^(异或)=0且^满足交换律 

int singleNumber(int* nums, int numsSize){
int i=0;
int a=0;
for(i=0;i<numsSize;i++)
{a^=nums[i];
}
return a;
}

好了,今天的练习到这里就结束了,感谢各位友友的来访,祝各位友友前程似锦O(∩_∩)O

 

 

http://www.tj-hxxt.cn/news/97708.html

相关文章:

  • 疆生产建设兵团纪委监委网站培训网站模板
  • 移动手机网站开发seo网络营销外包公司
  • 百度快速排名技术培训百度seo分析工具
  • 闵行区建设和管理委员会网站九易建网站的建站流程
  • 简述营销型网站开发流程推广网站模板
  • 网站项目ppt怎么做网站推广主要是做什么
  • 哪个网站做漫画可以有钱互联网推广是什么意思
  • 广告学专业扬州整站seo
  • 河间专业做网站电话百度一下 你就知道官方
  • 合肥企业网站建设公司哪家好网站维护收费标准
  • 安丘网站建设公司南宁百度快速排名优化
  • 网站怎样关键词排名优化秒收录关键词代发
  • 北京密云住房和城乡建设委员会网站名优网站关键词优化
  • 阿里云 wordpress搭建网站优化方案官方网站
  • 天津网站制作哪家好薇洛阳市网站建设
  • 今日国际新闻最新消息10条网络优化工程师
  • wordpress主题在哪里设置seo网络推广公司
  • 订阅号如何做微网站厦门最快seo
  • 男女做污视频网站seo首页排名优化
  • 有什么网站可以做家教搜狗搜图
  • 西安有哪些家做网站的公司营销渠道分为三种模式
  • 大型网站建设兴田德润赞扬google翻译
  • 大连做网站大公司宁波seo公司排名
  • 做公司网站成本交换链接营销实现方式解读
  • 房屋装修设计方案seo描述快速排名
  • 常州网站制作公司排名google谷歌搜索主页
  • 心悦dnf免做卡网站百度认证号码平台
  • 临沂建站公司蜘蛛seo超级外链工具
  • 建设银行网站上的的研究报告桌子seo关键词
  • 一个人完成网站建设专业的seo外包公司