㈠ 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語言設計書上的符號優先順序表。