【macOS终端使用代理Proxy】

  • 打开终端,运行
    
    open -t ~/.bash_profile   //.bash_profile 可以理解为Term打开后能够自动执行的脚本文件
    
  • 复制到.bash_profile
    
    export https_proxy=http://127.0.0.1:6152 //替换为你自己的代理
    export http_proxy=http://127.0.0.1:6152  //替换为你自己的代理
    
  • 保存配置,运行
    
    source ~/.bash_profile
    
  • 该方法配置好后,在IDEA等工具的终端下同样有用

【C语言 大数加法 减法 乘法】

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

void stringReverse(char * p)//逆序字符串
{
    int i,len;
    char temp;
    len = strlen(p);

    for(i=0; i<(len/2); i++)
    {
        temp = p[i];
        p[i] = p[len-1-i];
        p[len-1-i] = temp;
    }
}

char* getString()//动态字符串输入
{
    char *str;
    char *_str;
    int i=1;

    str=(char*)malloc(sizeof(char)*(i+1));

    while((str[i-1]=getchar())!='\n'){
        i+=1;

        _str=(char*)malloc(strlen(str)+1);
        str[i-1]='\0';

        strcpy(_str,str);
        free(str);

        str=(char*)malloc(sizeof(char)*(i+1));
        if(str==NULL){
            free(_str);
            printf("Not enough memory!");
            return NULL;
        }

        strcpy(str,_str);
        free(_str);
    }
    str[i-1]='\0';
    return str;
}

char* remove_0(char *c)//删除0
{
    char *temp,*ch;
    temp=c;
    while(*temp){
        if(*temp!='0') break;
        temp+=1;
    }

    ch=c;
    while(*temp){
        *ch=*temp;
        ch+=1;
        temp+=1;
    }
    *ch='\0';

    return c;
}

char* add(char *a,char *b)//加法
{
    char *c;
    char *ch1,*ch2,*ch3;
    int len=0;
    int i=0,j=0;
    int x=0,y=0;

    len = strlen(a)>=strlen(b) ? strlen(a) : strlen(b);

    c=(char*)malloc(sizeof(char)*(len+1));

    stringReverse(a);
    stringReverse(b);

    ch1=a;
    ch2=b;
    ch3=c;
    while(*ch1!='\0' || *ch2!='\0'){
        if(*ch1!='\0') i=*ch1-'0';
        if(*ch2!='\0') j=*ch2-'0';
        x=i+j+y;
        *ch3=(x%10)+'0';
        ch3+=1;
        y=x/10;
        if(*ch1!='\0') ch1+=1;
        if(*ch2!='\0') ch2+=1;
        i=0;
        j=0;
    }
    *ch3='\0';

    stringReverse(c);

    return c;
}


char* minus(char *a,char *b)//减法
{
    char *c;
    char *temp;
    char *ch1,*ch2,*ch3;
    int sign=0;
    int len=0;
    int i=0,j=0;
    int x=0,y=0;

    len = strlen(a)>=strlen(b) ? strlen(a) : strlen(b);

    c=(char*)malloc(sizeof(char)*len);

    if((strlen(a)==strlen(b) && strcmp(a,b)<0) || strlen(a)<strlen(b)){
        temp=a;
        a=b;
        b=temp;
        sign=1;
    }

    stringReverse(a);
    stringReverse(b);

    ch1=a;
    ch2=b;
    ch3=c;
    while(*ch1!='\0' || *ch2!='\0'){
        if(*ch1!='\0') i=*ch1-'0';
        if(*ch2!='\0') j=*ch2-'0';
        x=i-j-y;
        if(x<0){
            y=1;
            x+=10;
        }else{
            y=0;
        }
        *ch3=(x%10)+'0';
        ch3+=1;
        if(*ch1!='\0') ch1+=1;
        if(*ch2!='\0') ch2+=1;
        i=0;
        j=0;
    }
    *ch3='\0';

    stringReverse(c);

    remove_0(c);

    if(sign==0){
        return c;
    }else{
        printf("-");
        return c;
    }
}


char* by(char *a,char *b)//乘法
{
    char *c;
    int len=0;
    int temp=0;
    int i=0,j=0;
    int x=0,y=0;

    len=strlen(a)+strlen(b);

    stringReverse(a);
    stringReverse(b);

    c=(char*)malloc(sizeof(char)*(len+1));
    memset(c,0,sizeof(char)*(len+1));

    for(i=0;i<strlen(b);i+=1){
        for(j=0;j<strlen(a);j+=1){
            x=a[j]-'0';
            y=b[i]-'0';
            temp=x*y;
            c[i+j]+=temp;
        }
    }

    x=0;
    for(i=0;i<len;i+=1){
        c[i]+=x;
        x=c[i]/10;
        c[i]%=10;
    }

    for(i=0;i<len;i+=1){
        c[i]+='0';
    }

    stringReverse(c);

    remove_0(c);

    return c;
}

int main(){
    char *a,*b,*operator;

    printf("Infinite Positive Integer Operation\n");
    printf("-----------------------\n");

    printf("Please enter the first positive integer:\n");
    a=getString();

    printf("Please enter the operator(+ - * /):\n");
    operator=getString();

    printf("Please enter the second positive integer:\n");
    b=getString();

    printf("The result is:\n");

    switch (*operator){
        case '+':
            puts(add(a,b));
            break;
        case '-':
            puts(minus(a,b));
            break;
        case '*':
            puts(by(a,b));
            break;
            /*case '/':
                puts(divide(a,b));
                break;*/
        default:
            printf("error");
            break;
    }


    return 0;
}

【C语言 扫雷】

Minesweeper in C

C语言扫雷

9*9

可以自动消除一大片

代码如下:

#include <stdio.h>
#include <stdlib.h>
#include <time.h>

#define N 9 //9*9扫雷

int sum = 10; //雷数目
int mine[N][N] = {0}; //雷数组
int map[N][N]; //显示数组
int markDirection[8][2] = {{0,1},{1,1},{1,0},{1,-1},{0,-1},{-1,-1},{-1,0},{-1,1}}; //8个方向

void printMap() //打印地图
{
    int i = 0,j = 0;
    for(i=0;i<N;i++)
    {
        for(j=0;j<N;j++)
        {
            printf("%d ",map[i][j]);
        }
        printf("\n");
    }
}

void setMine() //埋雷
{
    srand((int)time(0));
    int x=0,y=0;

    while(sum >= 0)
    {
        x = (rand()%(9-1+1))+1;
        y = (rand()%(9-1+1))+1;

        if(mine[x][y] != 1)
        {
            mine[x][y] = 1;
            sum -= 1;
        }
    }
}

int countMine(int x,int y) //数雷
{
    int count=0;
    int x1 = 0, y1 = 0;
    int i = 0;
    
    for(i=0;i<N;i++)
    {
        x1 = x + markDirection[i][0];
        y1 = y + markDirection[i][1];
        if(x1<0 || x1>=N || y1<0 || y1>=N) continue;
        if(mine[x1][y1] == 1) count += 1;
    }
    return count;
}

void autoClear(int x,int y) //自动消一大片
{
    int x1 = 0, y1 = 0;
    int i = 0;
    int count = 0;
    
    map[x][y] = 0;
    
    for(i=0;i<N;i++)
    {
        x1 = x + markDirection[i][0];
        y1 = y + markDirection[i][1];
        if(x1<0 || x1>=N || y1<0 || y1>=N) continue;
        count = countMine(x1,y1);
        if(count != 0) 
        {
            map[x1][y1] = count;
        }else if(map[x1][y1]==0){
            continue;
        }else{
            autoClear(x1,y1);
        }
    }
}

int winCheck() //赢了吗
{
    int count = 0;
    int i=0,j=0;
    
    for(i=0;i<N;i++)
    {
        for(j=0;j<N;j++)
        {
            if(map[i][j] == 9) count += 1;
        }
    }
    if(count == sum)
    {
        return 1;
    }else{
        return 0;
    }
}

void Gameover() //炸了
{
    int i = 0,j = 0;
    for(i=0;i<N;i++)
    {
        for(j=0;j<N;j++)
        {
            printf("%d ",mine[i][j]);
        }
        printf("\n");
    }
}

int main()
{
    int X=0,Y=0;
    int i=0,j=0;
    int check=0;
    int result = 1;
    
    for(i=0;i<N;i++)
    {
        for(j=0;j<N;j++)
        {
            map[i][j] = 9;
        }
    }
        

    
    printf("*********扫雷**********\n");
    printMap();
    setMine();
    
    while(result)
    {
        printf("输入 行,列\n");
        scanf("%d,%d",&X,&Y);
        
        X -= 1;
        Y -= 1;
        
        if(mine[X][Y] == 1)
        {
            printf("Game over!\n");
            Gameover();
            result = 0;
        }else{
            check = countMine(X,Y);
            if(check != 0)
            {
                map[X][Y] = check;
            }else{
                autoClear(X,Y);
            }
            printMap();
        }
        
        if(winCheck())
        {
            printf("You win!");
            break;
        }
        
    }
    return 0;
}

 

代码:https://github.com/chiuxingxiang/Minesweeper-C

【制作微信支付宝二合一收款码(使用自己的服务器)】

  • 由于这个东西涉及到钱的为题,感觉还是用自己的服务器弄一个比较安全。

  • 其实原理十分简单:
    
    客户端扫码 -> 服务端根据 User-Agent 判断客户端类型 -> 分别返回支付宝和微信的二维码内容
    

  • 话不多少,开干。

    1.解码微信和支付宝的付款码

    支付宝:

    
    HTTPS://QR.ALIPAY.COM/TSX06990VFZIYPD04PEG95 (https 协议,可直接唤醒支付宝 APP)
    

    微信:

    
    wxp://f2f09zP7EA1FQhdQvgrisHYoS4Jr9CHhX7q5 (微信自己的协议链接,不允许外部调用)
    

    2.查看一下微信和支付宝在扫码,发送请求所携带的 User Agent 头信息

    支付宝:

    
    UCBrowser/11.5.0.939 UCBS/2.10.1.6 Mobile Safari/537.36 AliApp(AP/10.0.15.051805) AlipayClient/10.0.15.051805 Language/zh-Hans
    

    微信:

    
    MQQBrowser/6.2 TBS 043220 Safari/537.36 MicroMessenger/6.5.8.1060 NetType/4G Language/zh_CN
    
  • 这样就很轻松区分是微信还是支付宝扫码了:
    
    User Agent 含有 MicroMessenger 为微信
    
    User Agent 含有 ApliPayClient 为支付宝
    

    3.判断客户端 User Agent

  • 如果是支付宝直接跳转支付宝链接,微信返回收款二维码,自行长按扫码。

    代码如下(请加上php头尾):

    
        
            header("Content-type: text/html; charset=utf-8");
            $ua = $_SERVER['HTTP_USER_AGENT'];
            if (preg_match("/.+MicroMessenger.+/", $ua)) {
                $url = 'https://qxx.hk/wx.jpeg';
                header("location: " . $url);
            } elseif (preg_match("/.+AlipayClient.+/", $ua)) { 
            $url = 'HTTPS://QR.ALIPAY.COM/TSX06990VFZIYPD04PEG95';
            header("location: " . $url);
            } else { 
               echo "请使用支付宝或微信客户端扫码付款";
            }