1.å¦ä½ç¼ç¨åºä¸ä¸ªç±å¿
2.ch=getchar(); putchar(ch);和putchar(getchar())的区别。
3.(1)定义一个整型指针变量p,使它指向一个5个元素的一维数组. (2)使用指针移动的方式,输入5个整型数组元素.
4.如何用C语言将一个16进制数转换成10进制数,要求用函数。
å¦ä½ç¼ç¨åºä¸ä¸ªç±å¿
é¦å æå¼ä»£ç ç¼è¾å¨ï¼ç¶åè¾å ¥ä»£ç ãa=x*xy*y-1;charch=a*a*a-x*x*y*y*y<=0.0f?'*':'';putchar(ch)ãã
代ç 设计çååå æ¬å¯ä¸ç¡®å®æ§ãæ åååéç¨æ§ãå¯æ©å æ§ä¸ç¨³å®æ§ã便äºè¯å«ä¸è®°å¿ãåæ±çå°ä¸æ ¼å¼ç»ä¸ä»¥å容æä¿®æ¹çãæºä»£ç æ¯ä»£ç çåæ¯ï¼æç§æä¹ä¸æ¥è¯´ï¼æºä»£ç ç¸å½äºä»£ç ãç°ä»£ç¨åºè¯è¨ä¸ï¼æºä»£ç å¯ä»¥ä¹¦ç±æç£å¸¦å½¢å¼åºç°ï¼ä½æ为常ç¨æ ¼å¼æ¯ææ¬æ件ï¼è¿ç§å ¸åæ ¼å¼çç®çæ¯ä¸ºäºç¼è¯åºè®¡ç®æºç¨åºã
ch=getchar(); putchar(ch);和putchar(getchar())的区别。
ch=getchar(); putchar(ch);和putchar(getchar())实现的功能是一样的,只不过多了一个中间变量。ce源码编译
1.putchar函数的作用:向终端输出一个字符。
(1)putchar函数只能用于单个字符的输出,且一次只能输出一个字符。
(2)在程序中使用putchar函数,务必牢记:在程序(或文件)的开头加上编译预处理命令(也称包含命令),即:#include "stdio.h"。
getchar函数(单个字符的输入函数)
2.getchar函数的作用:从系统隐含的输入设备(如键盘)输入一个字符。
getchar函数只能用于单个字符的输入,一次输入一个字符。读懂android源码程序的功能是输入一个字符,显示一个字符,回车换行,再输入并显示一个字符。而运行时字符是连续输入的,运行结果却是正确的,这是网站源码招聘因为输入字符后,它们暂存于键盘的缓冲区中,然后由getchar函数从键盘缓冲区中一个一个的取出来。使用getchar函数时,在程序(或文件)的开头也必须加上编译预处理命
(1)定义一个整型指针变量p,使它指向一个5个元素的一维数组. (2)使用指针移动的方式,输入5个整型数组元素.
源代码如下:#include<stdio.h>
#include<stdlib.h>
int main(){
int a[5];
int *p=a; //定义一个整型指针变量p,使它指向一个5个元素的一维数组.
int i;
printf("Please input:");
for(i=0;i<5;i++)
scanf("%d",p+i); //使用指针移动的方式,输入5个整型数组元素.
int *q=(int*)malloc(sizeof(int)*5); //malloc函数动态分配5个整型数的地址空间。
printf("Please input:");
for(i=0;i<5;i++)
scanf("%d",q+i); //使用数组下标的方式输入5个整型元素。
for(i=0;i<5;i++)
if(p[i]>q[i]){
int t=p[i];
p[i]=q[i];
q[i]=t;
}
for(i=0;i<5;i++) //使用指针p和q分别访问两组数据
printf("%d",p[i]);
putchar('\n');
for(i=0;i<5;i++)
printf("%d",q[i]);
putchar('\n');
printf("p=%x\n",p); //分别输出交换后的两组数。
printf("a=%x\n",hotspot源码视频a);
printf("q=%x\n",q);
free(q);
q=NULL;//按十六进制方式输出p、a和q的地址。
return 0;
}
运行结果如下:
扩展资料:
指针的初始化、动态分配内存的方法
指针的初始化
对指针进行初始化或赋值只能使用以下四种类型的值 :
1. 0 值常量表达式,例如,在编译时可获得 0 值的整型 const对象或字面值常量 0。
2. 类型匹配的对象的地址。
3. 另一对象末的下一地址。
4. 同类型的modelmapper源码解读另一个有效指针。
把 int 型变量赋给指针是非法的,尽管此 int 型变量的值可能为 0。但允
许把数值 0 或在编译时可获得 0 值的 const 量赋给指针:
int ival;
int zero = 0;
const int c_ival = 0;
int *pi = ival; // error: pi initialized from int value of ival
pi = zero;// error: pi assigned int value of zero
pi = c_ival;// ok: c_ival is a const with compile-time value of 0
pi = 0;// ok: directly initialize to literal constant 0
除了使用数值 0 或在编译时值为 0 的 const 量外,还可以使用 C++ 语言从 C 语言中继承下来的预处理器变量 NULL,该变量在 cstdlib头文件中定义,其值为 0。
如果在代码中使用了这个预处理器变量,则编译时会自动被数值 0 替换。因此,把指针初始化为 NULL 等效于初始化为 0 值 [3] :
// cstdlib #defines NULL to 0
int *pi = NULL; // ok: equivalent to int *pi = 0;
动态分配内存的方法
new可用来生成动态无名变量
(1)new可用来生成动态无名变量
如 int *p=new int;
int *p=new int []; //动态数组的大小可以是变量或常量;而一般直接声明数组时,数组大小必须是常量
又如:
int *p1;
double *p2;
p1=new int⑿;
p2=new double [];
l 分别表示动态分配了用于存放整型数据的内存空间,将初值写入该内存空间,并将首地址值返回指针p1;
l 动态分配了具有个双精度实型数组元素的数组,同时将各存储区的首地址指针返回给指针变量p2;
对于生成二维及更高维的数组,应使用多维指针。
以二维指针为例
int **p=new int* [row]; //row是二维数组的行,p是指向一个指针数组的指针
for(int i=0; i<row; i++)
p[i]=new int [col]; //col是二维数组的列,p是指向一个int数组的指针
删除这个二维数组
for(int i = 0; i < row;i++)
delete []p[i]; //先删除二维数组的列
delete []p;
⑵使用完动态无名变量后应该及时释放,要用到 delete 运算符
delete p; //释放单个变量
delete [ ] p;//释放数组变量(不论数组是几维)
相比于一般的变量声明,使用new和delete 运算符可方便的使用变量。
百度百科-指针
百度百科-动态分配内存
如何用C语言将一个进制数转换成进制数,要求用函数。
我自己编写的一个函数。
楼上的根本没达到目的。赋值语句实现纯粹是投机取巧。考试肯定为0分。
下面是程序源代码
#include<stdio.h>
void
shuchu(int
c)
//这个函数不用编写,可以直接在zhs函数里面用语句写的//
{
c=c%;
if(c>=0&&c<=9)
{ c=c+;
putchar(c);
}
else
{
c=c+;
putchar(c);
}
}
void
zhs(int
c)
{
if(c<=)
shuchu(c);
else
{
zhs(c/);
shuchu(c);
}
}
void
main()
{
int
n;
printf("please
enter
a
number:\n");
scanf("%d",&n);
printf("zhuan
huan
hou
de
jinzhi
shushi
:\n");
zhs(n);
printf("\n");
}
不好意思弄错了这是一个十进制转换到进制的问题。我重新帮你写一个。