當前位置:首頁 » 編程軟體 » 編程回憶錄

編程回憶錄

發布時間: 2022-07-20 11:11:04

編程教父,編程回憶錄是騙子,不要浪費錢了,自己買本書也能錄視頻。。。

他就是一個弟中弟

Ⅱ 哪位編程高手,幫我用C++編寫一個完整的能運行的3DES加密演算法,謝謝!

/*在TC2 和 VC6下都可以順利運行。做了一個下午。一定要用我這個噢。有簡單的輸入錯誤檢測。有完整的說明和注釋*/#include<stdio.h> /*庫文件包含*/#include<string.h> /*用於字元串操作*/#include<stdlib.h> /*用於exit函數*//**************************************************************************int check(char *c)輸入參數: char *c: 輸入的字元串返回參數: 0:字元串中有不符合規定的字元 1: 字元串字元符合規定,沒有不符合規定的字元.功能: 檢查字元串中有否除了 0-9, +,-,*,/,(,),之外的其他字元, 如果有,則返回0, 表示出現錯誤。 若沒有,則返回1,表式字元串符合規定。**************************************************************************/int check(char *c){ int k=0; while(*c!='\0') { if((*c>='0' && *c<='9') || *c=='+' || *c=='-' || *c=='*' || *c=='/' || *c=='.' || *c=='(' || *c==')' ) { } else { printf("input error, there have the char not the math expression char!\n"); return 0; } if(*c=='(') k++; else if(*c==')') k--; c++; } if(k!=0) { printf("input error, there is not have correct bracket '()'!\n"); return 0; } return 1;}/**************************************************************************void move(char *f, double *s,int p) 輸入參數: char *f : 運算符數組 double *s: 數值數組 int p: 當前運算符數組位置。返回參數: 無功能: 將當前已經完成運算的運算符消去,同時將數值數組的位置調整以進行下一次運算。 傳入值p若為3 則當前符號的數組位置為3. f[3]=f[3+1].......f[len-2]=f[len-1] f[len-1]='\0'; s[i]=s[i+1].......s[len-1]=s[len] 因為數值比運算符多一個。***************************************************************************/void move(char *f, double *s,int p) { int i=0,len=strlen(f); for(i=p; i<len; i++) /*將已經運算過的符號,空出來的位置用後面的符號來填充,*/ { /*即把乘和除號的位置用後面的加和減號填充*/ f[i]=f[i+1]; s[i]=s[i+1]; } s[i]=s[i+1]; f[len-1]='\0';}/**************************************************************************double convnum(char *c)輸入參數: char *c :由數字和小數點組成的字元,用以轉換成double型的數值。返回參數: num:返回轉換好的值。功能: 將輸入的字元串先將其小數點以前的部分復制到temp[]數組中, 若有小數點,則將小數點之後的數值,也就是小數部分先進行計算,值存入num中 計算完成後,再對整數部分進行計算,值加上小數部分的值,存入num中。***************************************************************************/double convnum(char *c){ double num=0.0; double a=1.0; int i=0,p=0,len=0; char temp[100]; int tempi=0; int start=0; int f=1; /*正負符號指示器,若為1則為正數,為-1,此數為負數*/ len=strlen©; if(c[0]=='-') { start=1; f=-1; } for(i=start; i<len; i++) { if(c[i]=='.') { p=i; break; } temp[tempi++]=c[i]; /*將整數部分復制到temp[]中*/ } temp[tempi]='\0'; if(p!=0) { for(i=p+1;i<len;i++) /*將小數部分計算出來*/ { if(c[i]=='.') /*如果有多餘的小數點,則表示輸入錯誤*/ { printf("there is more that one dot '.' in number!error!\n"); exit(0); } a=a*0.1; num+=(a*(c[i]-48)); } } a=1.0; len=strlen(temp); /*計算整數部分*/ for(i=len-1;i>=0; i--) { num=num+(a*(temp[i]-48)); a*=10; } num=num*f; return num;}/**************************************************************************double good(char *c)輸入參數: char *c :即將進行運算的字元串型數學表達式。如3.5+(2*3/5)返回參數: s[0]:計算結果將放入s[0]中功能: 將輸入的字元串中的數字分別調用convnum(char *c)函數進行數值變換,再將其依 次存入doulbe s[i]中,將加減乘除運算符依次存入字元串符號數組 char f[i]中, 然後如果遇到括弧,則將括弧內的字元串存入另一字元數組中,然後用此 good(char *c) 遞歸函數進行遞歸運算。 然後根據先乘除,後加減的順序對已 存入數組的數值根 據存入字元串符號數組的運算符進行運算。結果存入s[0]中。 返回最終結果。***************************************************************************/double good(char *c) /*可遞歸函數*/{ /*取得數值字元串,並調用convnum轉換成double*/ char g[100],number[30]; /*g,保存當前的表達式串,number保存一個數的所有字元*/ char f[80]; /*保存所有的符號的堆棧*/ int fi=0; /*保存符號的位置指針*/ double s[80]; /*保存當前所有的數的一個堆棧*/ int si=0; /*保存數字位置指針*/ int k=0; /* 若k=1則表示有一對括弧*/ int num=0,i=0; /*num保存新括弧內的字元數,i 保存number里的字元位置*/ int cc=0; /*乘除符號數量*/ int jj=0; /*加減符號數量*/ while(*c!='\0')/*當p==1 和k==0時,表示已經把括弧里的內容全部復制到g[100]中了*/ { k=0; num=0; switch(*c) { case '+': /*當前字元為+-乘除時則表示*/ case '-': case '*': case'/': f[fi++]=*c; if(*c=='*' || *c=='/') cc++; else jj++; if(*(c-1)!=')') { number[i]='\0'; i=0;/*完成一個數字的復制,其位置指針i=0*/ s[si++]=convnum(number); } break; case'(': /*有括弧,則將當前括弧作用范圍內的全部字元保存,作為*/ k++; /*一個新的字元表達式進行遞歸調用good函數計算。*/ while(k>0) { c++; g[num]=*c; num++; if(*c==')') { k--; } else if(*c=='(') { k++; } } g[num-1]='\0'; num=0;/*完成一個括弧內容的復制,其位置指針num=0*/ s[si++]=good(g); break; default: number[i++]=*c; if(*(c+1)=='\0') { number[i]='\0'; s[si++]=convnum(number); } break; } c++; } f[fi]='\0'; i=0; while(cc>0) { switch(f[i]) { case '*': cc--; s[i+1]=s[i]*s[i+1]; move(f,s,i); break; case '/': cc--; s[i+1]=s[i]/(float)s[i+1]; move(f,s,i); break; default: i++; break; } } i=0; while(jj>0) { switch(f[i]) { case '+': s[i+1]=s[i]+s[i+1]; jj--; move(f,s,i); break; case '-': s[i+1]=s[i]-s[i+1]; jj--; move(f,s,i); break; default: printf("operator error!"); break; } } return s[0];}void main(){ char str[100]; double sum=0; int p=1; while(1) { printf("enter expression: enter 'exit' end of program\n"); scanf("%s",str); p=strcmp(str,"exit"); if(p==0) break; p=check(str); if(p==0) continue; sum=good(str); printf("%s=%f",str,sum); printf("\n"); } printf("good bye!\n");}例:enter expression: enter 'exit' end of program3.5+(12.3*15+8-(3/2+1))*2+(3.2*3-5)/6(輸入)3.5+(12.3*15+8-(3/2+1))*2+(3.2*3-5)/6=384.266667enter expression: enter 'exit' end of programchina(輸入)input error, there have the char not the math expression char!enter expression: enter 'exit' end of programexit(輸入)good bye!
如果你還有什麼不懂的,可以網路搜下:編程回憶錄,他們現在正在錄制這方面的教程,都是零基礎開始,由淺入深。

Ⅲ VB6.0編程,想把ACCESS07資料庫【ABC】中表1中的所有內容都復制到同一資料庫的表2裡面,求代碼。

在工程里引用microsoft activex data objects 2.7 library

Dim cn As New ADODB.Connection, rs1 As New ADODB.Recordset, sql As String '在通用聲明裡定義,其中cn是連接對象,rs1是記錄集,sql是查詢語句
Private Sub Form_Load()
cn.Open "provider=microsoft.jet.oledb.4.0;data source=" + App.Path + "\資料庫名.mdb" + ""
sql = "select * from 表名"
rs1.Open sql, cn
rs1.MoveFirst
Do While Not rs1.EOF
Combo1.AddItem rs1("欄位名")
rs1.MoveNext
Loop
rs1.Close
End Sub
如果你還有什麼不懂的,可以網路搜下:編程回憶錄,他們現在正在錄制這方面的教程,都是零基礎開始,由淺入深。

Ⅳ 編程實現:用秦九韶演算法求多項式p(x)=3x^5-2x^3+x+7在x=3處的值

p(x)=3x^5+0x^4-2x^3+0x^2+x+7
=(3x^4+0x^3-2x^2+0x+1)x+7
=((3x^3+0x^2-2x+0)x+1)x+7
=(((3x^2+0x-2)x+0)x+1)x+7
=((((3x+0)x-2)x+0)x+1)x+7
v[1]=3x+0=9
v[2]=v[1]x-2=25
v[3]=v[2]x+0=75
v[4]=v[3]x+1=226
v[5]=v[4]x+7=685
如果你還有什麼不懂的,可以網路搜下:編程回憶錄,他們現在正在錄制這方面的教程,都是零基礎開始,由淺入深。

Ⅳ 編程,輸入一個以回車結束的字元串(少於80個字元),

#include<iostream>
using namespace std;

int main()
{
char oper[80];//用來接收用戶輸入的字元串。
int num=0;//用來接收總字元數。
int NewNum=0;//用來接收新字元數。
int nChar;//用來接收每個字元的ASCII碼值。

gets(oper);//用戶輸入字元串,注意!這里不能用cin語句,因為cin會遇到空格停止。
for (int m=0;m<80;m++)
{
if (oper[m]=='\0')//字元串結尾符為'\0'。
{
num=m;
}
}//獲取用戶輸入的總字元數。

for (int i=0;i<num;i++)
{
nChar=(int)oper[i];//獲取每個字元的ASCII碼值。
if (nChar<65 || nChar>91)//大寫字母在ASCII碼之中是從65到91的。
{
oper[NewNum]=oper[i];
NewNum++;
}//如果輸入的不是大寫字母,則將其以新的順序填入數組。
}//獲得除去大寫字母的字元串。

for (int j=0;j<NewNum;j++)
{
cout<<oper[j];
}//輸出新的字元串。

cout<<endl<<"新的字元數有:"<<NewNum<<endl;

return 0;
}

Ⅵ 編程回憶錄的unity3d課程一共有多少課,我怎麼沒有找到全集啊

x一共有150集的課程,是中文的哦,現在還沒有錄制完成,暑假估計就錄完了。

熱點內容
跳轉頁源碼 發布:2024-09-17 03:13:05 瀏覽:542
html文件上傳表單 發布:2024-09-17 03:08:02 瀏覽:783
聊天軟體編程 發布:2024-09-17 03:00:07 瀏覽:725
linuxoracle安裝路徑 發布:2024-09-17 01:57:29 瀏覽:688
兩個安卓手機照片怎麼同步 發布:2024-09-17 01:51:53 瀏覽:207
cf編譯後沒有黑框跳出來 發布:2024-09-17 01:46:54 瀏覽:249
安卓怎麼禁用應用讀取列表 發布:2024-09-17 01:46:45 瀏覽:524
win10設密碼在哪裡 發布:2024-09-17 01:33:32 瀏覽:662
情逢敵手迅雷下載ftp 發布:2024-09-17 01:32:35 瀏覽:337
安卓如何讓軟體按照步驟自動運行 發布:2024-09-17 01:28:27 瀏覽:197