㈠ c语言中*yy是什么
如果是 int *yy 就是说yy是一个整型指针;
如果是a*yy,那就是运算里面的乘法
㈡ 关于C语言的一个问题
这个确实是变量,而且题中有定义。请注意在下面这一段代码中,每一行结束都用到的是逗号,只有最后一行是分号,也就是说变量 ix iy cx cy n2dy n2dydx d 都是int类型的变量,只不过是在定义的过程中对其进行了初始化。
int ix = (x2 - x1) > 0 ? 1 : -1,
iy = (y2 - y1) > 0 ? 1 : -1,
cx = x1,
cy = y1,
n2dy = dy * 2,
n2dydx = (dy - dx) * 2,
d = dy * 2 - dx;
㈢ C语言语句解释,高手请进!
主函数里
先把yy清空,yy是全局数组。
如果ReadDat()执行不成功,输出提示并返回。
否则执行CountRs();WriteDat();
ReadDat()里
以读方式打开目的文件,如果打开失败,返回不成功
把这一百行数据存入xx二维数组。如果读取出错,返回不成功。
关闭文件。
这个函数的难点是二维数组,实际上xx[100][11]可以看成这样一个东西:
把A[11]数据看为一个单元,xx就是由100个这样的单元组成的数组。fgets(xx[i],11,fp)中的xx[i]就是一个?[11]的char型数组。之所以它定为11,是因为每行有10个数据,再加一位'\0'作为结束。
CountRs()里
先清空yy
找出每一个 不是全0 且 不是全1 的行 把此行统计值存入yy
str = xx[i];//把指针指向行首第一字符
j = 0;//计数器
while (*str)//当指针不指空时执行循环
{
if (*str == '1')
j++;//如果当前指针指向的值为1,计数器+1
str++;//指针指向下一个字符
}
if (j!=0 && j!=10)//如果不全为0且不全为1
for (k=0; k<10; k++)
yy[k] += xx[i][k]-'0';//'0'是字符型,xx[i][k]-'0'得出一个int型(因为xx存的是字符,字符0减字符0得数字0,字符1减字符0得数字1)yy+=aa可以写为yy=yy+aa,所以就是把xx中的值累加至yy
WriteDat()里
就是写文件,应该没什么不明白的吧
这个题目里要求的是一位表示一个选票,我觉得应该是一个2进制位吧。但是你这个程序写的是一个CHAR、即一个BYTE表示一个选票。
㈣ 请问这个C语言问题 for (; *yy; yy++)什么作用
估计你是不理解for (; *yy; yy++)吧,这种样式的代码现在软件工程里非常不鼓励了,虽然简洁但是晦涩,一般我们会推荐写成for(; *yy != '\0'; yy++)。
这样写是不是觉得好懂了一些?其实就是遍历字符串yy,直到字符串结尾符'\0'出现。
㈤ C语言中十六进制字符数组转化为字符串
#include <stdio.h>
unsigned char s_des[100] = {0};
int length = 9;
unsigned char s_src[length] = {0xFE,0x01,0x52,0xFF,0xEF,0xBA,0x35,0x90,0xFA};
unsigned char IntToHexChar(unsigned char c)
{
if (c > 9)
return (c + 55);
else
return (c + 0x30);
}
int main()
{
unsigned char temp;
int i;
for (i=0; i<length; i++)
{
temp = s_src[i]&0xf0;
s_des[2*i] = IntToHexChar(temp >> 4);
temp = s_src[i]&0x0f;
s_des[2*i+1] = IntToHexChar(temp);
}
printf("*** %s *** ",s_des);
return 0;
}
(5)c语言中yy1扩展阅读:
十六进制表示方式
不同电脑系统、编程语言对于16进制数值有不同的表示方式:
Ada与VHDL用所基于的“数字引证”把16进制数包起来,例如“16#5A3#”。(注:Ada对整数和实数都可以使用从1到16中任何一个做为其基数。)而对于字节向量,VHDL使用字首x表示,例如,x"10",对应的二进制码为:"00010000"。
C语言、C++、Shell、Python、Java语言及其他相近的语言使用字首“0x”,例如“0x5A3”。开头的“0”令解析器更易辨认数,而“x”则代表十六进制(就如“O”代表八进制)。在“0x”中的“x”可以大写或小写。对于字符量C语言中则以x+两位十六进制数的方式表示,如xFF。
十六进制转义序列:如x1abf4,可以使用任意多的十六进制数字,直至不是十六进制数字为止;
16位的通用字符名(universe-character name):u后面必须跟4个十六进制数字(不足四位前面用零补齐),表示Unicode中在0至0xFFFF之内的码位(但不能表示0xD800到0xDFFF之内的码点,Unicode标准规定这个范围内的码位保留,不表示字符);
32位的通用字符名:U后面必须跟8个十六进制数字(不足八位前面用零补齐),表示Unicode中所有可能的码位(除0xD800到0xDFFF之外)。
C++11引进了十六进制浮点型字面常量。例如:0x1.2p10表示(1+2/16)×2=115210。实际上,Visual C++一直以来使用的C/C++语言标准库函数printf,%a作为类型说明符来格式化输出浮点型值即为上述格式。例如:printf("%a",1152.0);
C/C++在表示字符型字面常量时,可以用:
在VB、MSX BASIC、Quick BASIC和FreeBASIC中,使用字首“&H”来表示。
在HTML,十六进制字符可以用“x”,例如֣和֣效果应该无异。
Intel的汇编语言中用字尾“h”来标识16进位的数(若该数以字母起首,在前面会增加一个“0”)例如“0A3Ch”、“5A3h”
其他汇编器(AT&T、Motorola、6502),Pascal,Delphi和某些BASIC的版本使用字首“$”,例如“$5A3”
亦有用X'5A3'这类表示方式的,如于PL/I,COBOL及JCL中。这亦是IBM装载早期操作系统的大型机与小型机上最常用的数据格式。
由于表示方式没有单一、已协定的标准,所以以上的表示方式都有被使用,有时甚至在同一份论文上会出现几个不同的表示方式。但因为各方式之间没有太大的分歧,所以即使混合使用也没有构成问题。
其中最常用(或常见)表示十六进制数值的方式是将'0x'加在数字前,或在数字后加上小字16。例如0x2BAD和2BAD16都是表示十进制的11181(或1118110)。
在网页设计上十六进制是很常用的。HTML和CSS使用十六进制的表示法来表示网页上的特定颜色。使用#的符号来表示而非用个别的符号表示十六进制。
24-bit颜色可以用#RRGGBB的格式来表示,RR是颜色中红色成分的数值,GG是颜色中绿色成分的数值,BB颜色中蓝色成分的数值。举个例子,红色的阴影是十进制238,9,63可以编成#EE093F。
㈥ 请教C语言
其中有一个逻辑错误:
在第二个循环体内
判断xx[i][j]==1此句
如果在这一个选票中选了六个以上的人的话
就会造成count一直累加,可能等于6,7,8,9,10
然而在紧跟的语句:if(count>=6)判断count是否
大于等于6,这样一来就会出现将yy[k]多自加的情况,
你的答案中:
第二张选票选的人数为7,比6大了1
所以yy[k]多自加了1
你可以自己将逻辑该过来啊.....
㈦ C语言中int和float有什么区别啊
一、指代不同
1、int:是一种数据类型,在编程语言(C、C++、C#、Java等)中,是用于定义整数类型变量的标识符。
2、float:于存储单精度浮点数或双精度浮点数。
二、数据范围不同
1、int:int占用4字节,32比特,数据范围为-2147483648~2147483647[-2^31~2^31-1]。
2、float:loat 类型提供了一个在 -3.4E+38 ~ 3.4E+38 之间的范围。
三、特点不同
1、int:除了int类型之外,还有short、long、long long类型可以表示整数。
2、float:可以提升为更大基数的类型(从 float 类型到 double 类型)。对浮点变量执行算术时,通常会出现提升。此算术始终以与具有最高精度的变量一样高的精度执行。
㈧ 这个C语言是什么意思,求解释
{/*xr=!xr;*/yy=1;yg=0} /* */之间是注释 就是这句是注掉的 不执行
然后yy=1;yg=0;
㈨ C语言中y---1是什么意思
先说--吧,--是一元运算符,如果--运算符位于变量的左边,那么在变量所在的表达式未进行计算之前,先将该变量减少1,如果位于该变量的右边,就在表达式运算完成之后再减少1。还有一个和这个符号类似的++,也类似。这里的y---1,如果你想看起来好看些,应该写成:
y--
-
1,就是这么一个意思。
举例说明:
int
x,
y
=
3;
x
=
y---1;
这句语句执行之后,x
的值是2,y
的值是2.
还有这个++也是这么回事。自己写个程序好好领悟下吧,这个没有什么难的,主要是逻辑问题。
希望对你有帮助!
补充,我看有兄弟说“y--
-
1,--需要左值,,不可能--1,只能y--,所以简单点说,就是等价于(y--)
-
1;”,这个说法是错误的,因为()也是运算符,而且优先级最高。若按照y---1
不等价于
(y--)
-
1,
同理举例:
int
x,y
=
3;
x
=
(y--
)
-
1;
这句语句执行后,x
的值是
1,
y的值是2
.原因是程序会首先计算括号里的表达式。这点请注意。如果你想知道更全面,请参照下C语言设计书上的符号优先级表。