C语言经典代码练习题

1.输入一个4位数:输出这个输的个位 十位 百位 千位

#include <stdio.h>
int main(int argc, char const *argv[])
{int a;printf("输入一个4位数:");scanf("%d",&a);printf("个位:%d\n",a%10);printf("十位:%d\n",a%100/10);printf("百位:%d\n",a/100%10);printf("千位:%d\n",a/1000);return 0;
}

2.从键盘读入两个整数,输出他们的和

#include <stdio.h>
int main(int argc, char const *argv[])
{int a,b;printf("输入第一个整数:");scanf("%d",&a);printf("输入第二个整数:");scanf("%d",&b);printf("它们的和:%d\n",a+b);return 0;
}

3.一个水分子的质量约为3.0*10^-23g,1夸脱水大约有950g,编写一个程序,要求输入水的夸脱数,然后显示这么多水中包含多少水分子。表示:3.0e-23 打印格式:%f或%e

#include <stdio.h>
int main(int argc, char const *argv[])
{int a;printf("输入水的夸脱数:");scanf("%d",&a);printf("%d夸脱水包含%f水分子\n",a,a*950/3.0e-23);return 0;
}

4.实现大小写转换(用getchar、putchar实现)即如果是大写字母转成小写输出如果是小写字母转为大写输出。

#include <stdio.h>
int main(int argc, char const *argv[])
{int a=getchar();if(65<=a&&a<=90){putchar(a+32);putchar(10);}else if (a>=97&&a<=122){putchar(a-32);putchar(10);}return 0;
}

5.从终端输入3个整数;从大到小输出。

#include <stdio.h>
int main(int argc, char const *argv[])
{int a, b, c;printf("请输入三个整数:\n");scanf("%d%d%d", &a, &b, &c);if (a <= b){int m;m = a;a = b;b = m;}if (b >= c)printf("%d %d %d\n", a, b, c);else if (a >= c && c >= b)printf("%d %d %d\n", a, c, b);elseprintf("%d %d %d\n", c, a, b);return 0;
}

6.输入任意两个数,输出两数之间(包括这两个数)偶数之和

#include <stdio.h>
int main(int argc, char const *argv[])
{int a, b, c;int sum = 0;printf("输入任意两个数:\n");scanf("%d%d", &a, &b);if (a > b){c = a;a = b;b = c;}for (int i = a; i <= b; i++){if (i % 2 == 0)sum += i;}printf("%d与%d偶数之和为%d\n", a, b, sum);return 0;
}

7.写程序实现功能:读入两个整数(data1和data2)和一个运算符(op),计算表达式data1 op data2 的值.其中op可以为+、-、*、/四个符号中的任一种(用switch语句实现)

#include <stdio.h>
int main(int argc, char const *argv[])
{int a, b;char c;printf("输入两个整数:\n");scanf("%d%d", &a, &b);getchar();printf("输入一个运算符(+、-、*、/):\n");scanf("%c", &c);switch (c){case '+':printf("%d%c%d=%d\n", a, c, b, a + b);break;case '-':printf("%d%c%d=%d\n", a, c, b, a - b);break;case '*':printf("%d%c%d=%d\n", a, c, b, a * b);break;case '/':printf("%d%c%d=%d\n", a, c, b, a / b);break;}return 0;
}

8.终端输入十个数,去掉其中最大值和最小值,求平均值。

#include <stdio.h>
int main(int argc, char const *argv[])
{int a[10];int max, min;int sum = 0;printf("输入十个数:\n");for (int i = 0; i < 10; i++){scanf("%d", &a[i]);sum += a[i];}for (int i = 0; i < 10; i++){max = a[0];min = a[0];if (a[i] > max)max = a[i];if (a[i] < min)min = a[i];}printf("sum=%d\n", sum);printf("max=%d\n", max);printf("min=%d\n", min);printf("去掉最大值和最小值,平均值为:%f\n", (float)(sum - max - min) / 8);return 0;
}

9.计算斐波那契数列前15项并逆序输出。

#include <stdio.h>
int main(int argc, char const *argv[])
{int a[15] = {1, 1};for (int i = 2; i < 15; i++){a[i] = a[i - 2] + a[i - 1];}for (int i = 14; i >= 0; i--)printf("%d\n", a[i]);return 0;
}

10.循环输入一个5位数,判断它是不是回文数。当输入0时循环结束。即12321是回文数,个位与万位相同,十位与千位相同。

#include <stdio.h>
int main(int argc, char const *argv[])
{int a;printf("输入一个5位数:");while (1){scanf("%d", &a);if (a == 0)break;if ((a % 10 == a / 10000) && (a / 10 % 10 == a / 1000 % 10))printf("是回文数\n");elseprintf("不是回文数\n");printf("输入一个5位数:");}return 0;
}

11.输入一个字符串,大小写转换输出。

#include <stdio.h>
#include <string.h>
int main(int argc, char const *argv[])
{char a[33] = {};scanf("%s", a);int n = strlen(a);for (int i = 0; i < n; i++){if (a[i] >= 'a' && a[i] <= 'z')printf("%c", a[i] - 32);else if (a[i] >= 'A' && a[i] <= 'Z')printf("%c", a[i] + 32);}return 0;
}

12.冒泡排序。

#include <stdio.h>
int main(int argc, char const *argv[])
{int a[5] = {6, 5, 4, 2, 3};for (int i = 0; i < 4; i++){for (int j = 0; j < 4 - i; j++){if (a[j] > a[j + 1]){a[j] = a[j] ^ a[j + 1];a[j + 1] = a[j] ^ a[j + 1];a[j] = a[j] ^ a[j + 1];}}}for (int i = 0; i < 5; i++){printf("%d", a[i]);}return 0;
}

13.选择排序。

#include <stdio.h>
int main(int argc, char const *argv[])
{int a[5] = {5, 4, 6, 9, 7};int temp;for (int i = 0; i < 4; i++){int min = i;for (int j = i + 1; j < 5; j++){if (a[j] < a[min])min = j;}temp=a[i];a[i]=a[min];a[min]=temp;}for (int i = 0; i < 5; i++)printf("%d", a[i]);return 0;
}

14.字符串逆序输出(两种方法实现)。

#include <stdio.h>
#include <string.h>
int main(int argc, char const *argv[])
{// 字符串逆序输出// 法1// char a[] = "hello world";// char *p = a;// int n = strlen(a);// for (int i = n; i >= 0; i--)// {//     printf("%c ", p[i]);// }char a[] = "hello world";char *p = a + strlen(a) - 1;for (int i = 0; i < strlen(a); i++){printf("%c", *p);p--;}// 法2// char a[] = "hello world";// char *p = a;// int n = strlen(a);// for (int i = 0; i < n / 2; i++)// {//     p[i] = p[i] ^ p[n - i - 1];//     p[n - i - 1] = p[i] ^ p[n - i - 1];//     p[i] = p[i] ^ p[n - i - 1];// }// printf("%s", p);// return 0;char a[66];gets(a);char *p = a;char *q = a + strlen(a) - 1;while (p < q){*p = *p ^ *q;*q = *p ^ *q;*p = *p ^ *q;p++;q--;}printf("%s", a);return 0;
}

15.字符串转数字:"1234" -----> 1234(一千两百三十四)。

#include <stdio.h>
#include <string.h>
int main(int argc, char const *argv[])
{// 字符串转数字//法1// char a[33];// gets(a);// int n=strlen(a);// int sum=0;// int j;// for (int i = 1; i < n; i++)// {//     j*=10;// }   // for (int i = 0; i < n; i++)// {//     sum+=(a[i]-48)*j;//     j/=10;// }// printf("%d\n", sum);// return 0;//法2char a[33];gets(a);char *p=a;int n=0;while (*p!='\0'){n=n*10+(*p-48);p++;}printf("%d\n",n);
}

16.打印杨辉三角前十行(二维数组)。

#include <stdio.h>
int main(int argc, char const *argv[])
{// 打印杨辉三角前十行// 法1//  int a[10][10] = {0};//  for (int i = 0; i < 10; i++)//  {//      for (int j = 0; j <= i; j++)//      {//          if (j - 1 >= 0)//              a[i][j] = a[i - 1][j - 1] + a[i - 1][j];//          else//              a[i][j] = 1;//      }//  }//  for (int i = 0; i < 10; i++)//  {//      for (int j = 0; j <= i; j++)//          printf("%-3d ", a[i][j]);//      printf("\n");//  }// 法2int a[10][10] = {};for (int i = 0; i < 10; i++){a[i][0] = 1;a[i][i] = 1;}for (int i = 2; i < 10; i++){for (int j = 1; j < 10; j++)a[i][j] = a[i - 1][j - 1] + a[i - 1][j];}for (int i = 0; i < 10; i++){for (int j = 0; j <= i; j++)printf("%d ", a[i][j]);putchar(10);}
}

17.已知字符数组a[10]和b[10]中元素的值递增有序,用指针实现将两个数组中元素按照递增顺序输出。如:char a[10]=”acdgjmno” ; char b[10]=”befhil”;->”abcdefghijlmno”

#include <stdio.h>
#include <string.h>
int main(int argc, char const *argv[])
{char a[10] = "acdgjmno";char b[10] = "befhil";char *p = a, *q = b;int i = 0, j = 0;while (i < strlen(a) && j < strlen(b)){if (p[i] < q[j]){printf("%c", p[i]);i++;}else{printf("%c", q[j]);j++;}}if (i < strlen(a)){for (int k = i; k < strlen(a); k++)printf("%c", a[k]);}if (j < strlen(b)){for (int k = j; k < strlen(b); k++)printf("%c", b[k]);}return 0;
}

18.给定一串字符"I love china",实现以单词为单位的逆序,如:"china love i"

#include <stdio.h>
#include <string.h>
int main(int argc, char const *argv[])
{char a[] = "i love china";char *p = a;int n = strlen(a);for (int i = 0; i < n / 2; i++){p[i] = p[i] ^ p[n - i - 1];p[n - i - 1] = p[i] ^ p[n - i - 1];p[i] = p[i] ^ p[n - i - 1];}char *q;char *k=NULL, temp;p = q = a;while (*p != '\0'){while (*p == ' ' )p++;q = p;while (*q != ' ' && *q != '\0')q++;k = q;q = k - 1;while (p < q){temp = *p;*p = *q;*q = temp;p++;q--;}p = k;}printf("%s\n", a);return 0;
}

19.定义求x的n次方值的函数( x是实数, n为正整数)。

#include <stdio.h>int fun(int x, int n)
{int r = 1;for (int i = 0; i < n; i++)r *= x;printf("%d\n", r);return r;
}int main(int argc, char const *argv[])
{// int r = 1;// int x = 2;// for (int i = 0; i < 4; i++)//     r *= x;// printf("%d\n", r);printf("%d\n", fun(2, 4));
}

20.编写一个函数,函数的2个参数,第一个是一个字符,第二个是一个char *,返回字符串中该字符的个数。

#include <stdio.h>int fun(char ch, char *p)   //ch=a='a', p=s
{int n = 0;while (*p != '\0') //*p{if (*p == ch)n++;p++; //p=p+1}return n;
}int main(int argc, char const *argv[])
{char a = 'a';char s[32] = "abbba";printf("%d\n", fun(a, s));
}

21.编程实现strlen函数的功能,strlen计算字符串实际长度,不包含'\0'

#include <stdio.h>int fun(char *p)
{int n = 0;while (*p){n++;p++;}return n;
}int main(int argc, char const *argv[])
{char s[32] = "abbba";int len = 0;len = fun(s);printf("%d\n", len);//printf("%d\n", fun(s));//printf("%d\n", fun("6666666"));
}

22.字符串"123"转换成整型123

#include <stdio.h>int fun(char *p)
{int sum = 0;while (*p != '\0'){sum = sum * 10 + (*p - 48);p++;}return sum;
}int main(int argc, char const *argv[])
{char str[32] = "123";printf("%d\n", fun(str));
}

23.封装函数实现两数交换。

#include <stdio.h>
void fun(int *x, int *y)
{int tmp;tmp = *x;*x = *y;*y = tmp;
}int main(int argc, char const *argv[])
{int a = 10, b = 20;fun(&a, &b);printf("%d %d\n", a, b);
}

24.封装函数实现strcpy功能。

#include <stdio.h>void fun(char *p, char *q)
{while (*q != '\0')*p++ = *q++;  //*p=*q; p++; q++;*p = '\0';
}int main(int argc, char const *argv[])
{char a[32] = "";char b[32] = "hello";fun(a, b);printf("%s\n", a);
}

25.封装函数实现strcat功能。

#include <stdio.h>
#include <string.h>
void fun(char *p, char *q)
{while (*p)   //p=p+strlen(p);p++;while (*q)*p++ = *q++;*p = '\0';
}int main(int argc, char const *argv[])
{char a[32] = "hello";char b[32] = "world";fun(a, b);printf("%s\n", a);
}

26.用递归函数求5的阶乘5!

#include <stdio.h>
#include <string.h>int fac(int n)   //n=5  n=4 n=3 n=2 n=1
{if (n == 1)return 1;       //fac(1)=1if (n > 1)return n * fac(n - 1);  //递推阶段:5*fac(4)  fac(4)=4*fac(3) fac(3)=3*fac(2) fac(2)=2*fac(1)//回归阶段:==> fac2(2)=2*1=2 ==>fac(3)=3*2=6 ==> fac(4)=4*6=24 ==>fac(5)=5*24=120
}int main(int argc, char const *argv[])
{int n = 5;printf("%d\n", fac(n));
}

27.斐波那契数列:指的是这样一个数列:1、1、2、3、5、8、13、21、34、……在数学上,斐波纳契数列以如下被以递归的方法定义:F(1)=1,F(2)=1, F(n)=F(n-1)+F(n-2)(n>=2,n∈N*) 求第五个数。

#include <stdio.h>
#include <string.h>int fac(int n)   //5 4 
{if (n == 1 || n == 2)return 1;if (n > 2)return fac(n - 1) + fac(n - 2);   //fac(5)=fac(4)+fac(3)= fac(3)+fac(2) +fac(3) = 5
}int main(int argc, char const *argv[])
{int n = 5;printf("%d\n", fac(n));
}

28.创建一个名为student的结构体,包含姓名,学号,班级,从终端输入学生的信息并打印。

#include <stdio.h>
#include <string.h>
struct student
{char name[32];int id;int class;
};struct student s1;
int main(int argc, char const *argv[])
{scanf("%s %d %d", s1.name, &s1.id, &s1.class);printf("%s %d %d\n", s1.name, s1.id, s1.class);
}

29.typedef用法

#include <stdio.h>
#include <string.h>
//1.给普通变量重命名
typedef int size4;//2. 给指针类型重命名
typedef int *int_p;//3. 给数组类型重名
typedef int intArr5[5];int main()
{size4 a = 10;                    //等同于int a=10;int_p p = &a;                    //等同于int *p=&a;intArr5 arr = {1, 2, 3, 4, 5}; //等同于int arr[5]={1,2,3,4,5};printf("%d\n", *p);     //10printf("%d\n", arr[3]);  //4
}

30.创建一个描述手机的结构体叫phone, 包含品牌,型号,颜色,价格。从终端输入你自己手机的信息并打印。(用typedef)。

#include <stdio.h>
#include <string.h>
typedef struct phone
{char brand[32];char type[32];char color[32];int price;
} ph;ph my;
int main()
{scanf("%s %s %s %d", my.brand, my.color, my.type, &my.price);printf("%s %s %s %d\n", my.brand, my.color, my.type, my.price);
}

31.创建一个名为student的结构体数组,包含学号,姓名,成绩,(数据类型自己定义),从终端输入学生的信息并打印分数及格的学生信息(输入3人即可)。

#include <stdio.h>
typedef struct student
{char name[32];int number;int score;
} st;int main(int argc, char const *argv[])
{st s[3];for (int i = 0; i < 3; i++)scanf("%s %d %d", s[i].name, &s[i].number, &s[i].score);for (int i = 0; i < 3; i++){if (s[i].score >= 60)printf("%s %d %d\n", s[i].name, s[i].number, s[i].score);}return 0;
}

32.创建一个结构体数组,数组名为book,结构体成员包含编号,书名,售价(数据类型自己设定)。写一个函数,包含两个形参,分别接收结构体数组的首地址和一个指定的售价,函数的功能为打印结构体数组中售价大于指定售价的书的信息。

#include <stdio.h>
#define N 3
typedef struct book
{char name[32];int id;int price;
} BOOK; //BOOK等同于struct bookBOOK b[N] = {{"shuihu", 1, 40},{"zyj zhuan", 2, 200},{"tuling zhuan", 3, 0}};void bookPri(BOOK *p, int n)
{for (int i = 0; i < N; i++){if (p->price > n)printf("%s %d %d\n", p->name, p->id, p->price);p++;}
}int main(int argc, char const *argv[])
{bookPri(b, 6);return 0;
}

33.创建一个游戏英雄的结构体数组(5个元素), 结构体成员包含名称, 血量和价格。给出每个英雄信息,封装函数实现按价格从低到高打印英雄信息,(用冒泡排序)。封装函数实现修改英雄信息功能。

#include <stdio.h>typedef struct hero
{char name[32];int hp;int price;
} HERO;void sort(HERO *p, int n)
{HERO tmp;for (int i = 0; i < n - 1; i++){for (int j = 0; j < n - i - 1; j++){if (p[j].price > p[j + 1].price){tmp = p[j];p[j] = p[j + 1];p[j + 1] = tmp;}}}
}void change(HERO *p, int n)
{if (n <= 3)scanf("%s %d %d", p[n - 1].name, &p[n - 1].hp, &p[n - 1].price);elseprintf("err\n");
}int main(int argc, char const *argv[])
{HERO a[3] = {{"zdl", 1, 50},{"zyj", 999, 100},{"xyb", 10000, 2}};change(a, 1);sort(a, 3);for (int i = 0; i < 3; i++)printf("%s %d %d\n", a[i].name, a[i].hp, a[i].price);return 0;
}

34.封装函数实现冒泡排序。

#include <stdio.h>void fun(int *a, int n)
{for (int i = 0; i < n - 1; i++){for (int j = 0; j < n - 1 - i; j++){if (a[j + 1] > a[j]){int temp = a[j];a[j] = a[j + 1];a[j + 1] = temp;}}}for (int i = 0; i < 10; i++)printf("%d ", a[i]);printf("\n");
}int main(int argc, char const *argv[])
{int a[10] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};fun(a, 10);return 0;
}

35.封装函数实现如下功能:输入任意两个数,返回两数之间(包括这两个数)偶数之和。

#include <stdio.h>int fun(int a, int b)
{int sum = 0;if (a >= b){int t = a;a = b;b = t;}for (int i = a; i <= b; i++){if (i % 2 == 0)sum += i;}return sum;
}int main(int argc, char const *argv[])
{int a, b, sum;scanf("%d %d", &a, &b);sum = fun(a, b);printf("%d\n", sum);return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/37128.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

微服务》》Kubernetes (K8S) 集群配置网络》》Calico

嘻嘻嘻 以Calico 为例子 Calico官网 官网上有安装Calico插件的步骤 步骤 要在主节点 主节点 主节点 执行 kubectl create -f https://raw.githubusercontent.com/projectcalico/calico/v3.29.2/manifests/tigera-operator.yaml kubectl create -f https://raw.githubuse…

蓝桥杯关于栈这个数据结构的一个算法题目

文章目录 1.题目概述解释2.思路分析3.代码解析 1.题目概述解释 找出来这个字符串里面重复出现的字符&#xff0c;类似于这个消消乐的游戏&#xff1b; 示例一里面的这个bb是连续的并且是一样的这个字符&#xff0c;因此删除bb&#xff0c;删除之后发现这个aa有一次相邻了&…

打破煤矿通信屏障,无线系统赋能生产安全与智能进阶

项目背景 在煤矿行业智能化转型的浪潮中&#xff0c;七台河矿业局积极回应国家煤矿智能化建设的号召&#xff0c;采取了具有前瞻性的战略举措——在七台河地区的煤矿部署了“井上井下”无线覆盖与广播一体化系统。此举旨在消除井上与井下之间的通信障碍&#xff0c;加强矿业局与…

基于CNN的FashionMNIST数据集识别4——GoogleNet模型

源码 import torch from torch import nn from torchsummary import summaryclass Inception(nn.Module):def __init__(self, in_channels, c1, c2, c3, c4):super().__init__()self.ReLu nn.ReLU()#路径1self.p1_1 nn.Conv2d(in_channelsin_channels, out_channelsc1, kern…

面试题精选《剑指Offer》:JVM类加载机制与Spring设计哲学深度剖析-大厂必考

一、JVM类加载核心机制 &#x1f525; 问题5&#xff1a;类从编译到执行的全链路过程 完整生命周期流程图 关键技术拆解 编译阶段 查看字节码指令&#xff1a;javap -v Robot.class 常量池结构解析&#xff08;CONSTANT_Class_info等&#xff09; 类加载阶段 // 手动加载…

(2025|ICLR|华南理工,任务对齐,缓解灾难性遗忘,底层模型冻结和训练早停)语言模型持续学习中的虚假遗忘

Spurious Forgetting in Continual Learning of Language Models 目录 1. 引言 2. 动机&#xff1a;关于虚假遗忘的初步实验 3. 深入探讨虚假遗忘 3.1 受控实验设置 3.2 从性能角度分析 3.3 从损失景观角度分析 3.4 从模型权重角度分析 3.5 从特征角度分析 3.6 结论 …

【css酷炫效果】纯CSS实现火焰文字特效

【css酷炫效果】纯CSS实现火焰文字特效 缘创作背景html结构css样式完整代码基础版进阶版(冰霜版) 效果图 想直接拿走的老板&#xff0c;链接放在这里&#xff1a;https://download.csdn.net/download/u011561335/90492005 缘 创作随缘&#xff0c;不定时更新。 创作背景 刚…

专访LayaAir引擎最有价值专家-施杨

在 LayaAir 引擎的资源商店中&#xff0c;许多开发者都会注意到一个熟悉的名字——“射手座”。他不仅贡献了大量高质量的 Shader 资源&#xff0c;让一些开发者通过他的作品了解到 LayaAir 引擎在 3D 视觉效果上的更多可能&#xff0c;也让大家能够以低成本直接学习并应用这些…

大模型详细配置

Transformer结构 目前主力大模型都是基于Transformer的&#xff0c;以下是Transformer的具体架构 它由编码器(Encoder)以及解码器(Decoder)组成&#xff0c;前者主要负责对输入数据进行理解&#xff0c;将每个输入 词元都编码成一个上下文语义相关的表示向量&#xff1b;后者…

鸿蒙NEXT项目实战-百得知识库04

代码仓地址&#xff0c;大家记得点个star IbestKnowTeach: 百得知识库基于鸿蒙NEXT稳定版实现的一款企业级开发项目案例。 本案例涉及到多个鸿蒙相关技术知识点&#xff1a; 1、布局 2、配置文件 3、组件的封装和使用 4、路由的使用 5、请求响应拦截器的封装 6、位置服务 7、三…

Python数据可视化实战:从基础图表到高级分析

Python数据可视化实战&#xff1a;从基础图表到高级分析 数据可视化是数据分析的重要环节&#xff0c;通过直观的图表可以快速洞察数据规律。本文将通过5个实际案例&#xff0c;手把手教你使用Python的Matplotlib库完成各类数据可视化任务&#xff0c;涵盖条形图、堆积面积图、…

修改原生的<input type=“datetime-local“>样式

效果 基础样式 <input type"datetime-local" class"custom-datetime">input[type"datetime-local"] {/* 重置默认样式 */-webkit-appearance: none;-moz-appearance: none;appearance: none; // 禁用浏览器默认样式/* 自定义基础样式 */w…

scrapy入门(深入)

Scrapy框架简介 Scrapy是:由Python语言开发的一个快速、高层次的屏幕抓取和web抓取框架&#xff0c;用于抓取web站点并从页面中提取结构化的数据&#xff0c;只需要实现少量的代码&#xff0c;就能够快速的抓取。 新建项目 (scrapy startproject xxx)&#xff1a;新建一个新的…

fetch,ajax,axios的区别以及使用

fetch,ajax,axios这些都是发起前端请求的工具&#xff0c;除了这些外还有jquery的$.ajax。ajax和$.ajax都是基于XMLHttpRequest。 介绍下XMLHttpRequest XMLHttpRequest是一种在浏览器中用于与服务器进行异步通信的对象&#xff0c;它是实现 AJAX&#xff08;Asynchronous Ja…

微信小程序的业务域名配置(通过ingress网关的注解)

一、背景 微信小程序的业务域名配置&#xff08;通过kong网关的pre-function配置&#xff09;是依靠kong实现&#xff0c;本文将通过ingress网关实现。 而我们的服务是部署于阿里云K8S容器&#xff0c;当然内核与ingress无异。 找到k8s–>网络–>路由 二、ingress注解 …

LiteratureReading:[2016] Enriching Word Vectors with Subword Information

文章目录 一、文献简明&#xff08;zero&#xff09;二、快速预览&#xff08;first&#xff09;1、标题分析2、作者介绍3、引用数4、摘要分析&#xff08;1&#xff09;翻译&#xff08;2&#xff09;分析 5、总结分析&#xff08;1&#xff09;翻译&#xff08;2&#xff09;…

前后端联调解决跨域问题的方案

引言 在前后端分离的开发模式中&#xff0c;前端和后端通常在不同的服务器或端口运行&#xff0c;这样就会面临跨域问题。跨域问题是指浏览器因安全限制阻止前端代码访问与当前网页源不同的域、协议或端口的资源。对于 Java 后端应用&#xff0c;我们可以通过配置 CORS&#x…

开源软件许可证冲突的原因和解决方法

1、什么是开源许可证以及许可证冲突产生的问题 开源软件许可证是一种法律文件&#xff0c;它规定了软件用户、分发者和修改者使用、复制、修改和分发开源软件的权利和义务。开源许可证是由软件的版权所有者&#xff08;通常是开发者或开发团队&#xff09;发布的&#xff0c;它…

python爬虫笔记(一)

文章目录 html基础标签和下划线无序列表和有序列表表格加边框 html的属性a标签&#xff08;网站&#xff09;target属性换行线和水平分割线 图片设置宽高width&#xff0c;height html区块——块元素与行内元素块元素与行内元素块元素举例行内元素举例 表单from标签type属性pla…

电脑节电模式怎么退出 分享5种解决方法

在使用电脑的过程中&#xff0c;许多用户为了节省电力&#xff0c;通常会选择开启电脑的节能模式。然而&#xff0c;在需要更高性能或进行图形密集型任务时&#xff0c;节能模式可能会限制系统的性能表现。这时&#xff0c;了解如何正确地关闭或调整节能设置就显得尤为重要了。…