1.输入平面上的一个坐标点P(x,y),判断该点的位置。(即指出坐标点是在原点还是在第几象限)。
2.在主函数中输入n,计算1!+2!+3!....n!的值输出。要求定义一个求阶乘的函数fct(n),计算n!的值。
3.输入一个字符串,对字符串进行加密,将加密后的字符串在屏幕上输出,同时将它保存到文件c:\a.txt中。其中对字符串的加密规则:字符串中小写字母改为大写字母,数字字符‘0’、‘1’…‘8’、‘9’分别改为‘1’、‘2’… ‘9’、‘0’,其余字符不变。
例如:输入字符串为 “Windows 90/95/xp”,加密后的字符串:“WINDOWS 01/06/XP”。
题1:
程序代码
#include <stdio.h>
int main() {
double x, y;
// 输入坐标点 P(x, y)
printf("请输入坐标点 P(x, y) 的坐标值:\n");
printf("x = ");
scanf("%lf", &x);
printf("y = ");
scanf("%lf", &y);
// 判断坐标点的位置
if (x == 0 && y == 0) {
printf("坐标点 P(%lf, %lf) 位于原点\n", x, y);
} else if (x > 0 && y > 0) {
printf("坐标点 P(%lf, %lf) 位于第一象限\n", x, y);
} else if (x < 0 && y > 0) {
printf("坐标点 P(%lf, %lf) 位于第二象限\n", x, y);
} else if (x < 0 && y < 0) {
printf("坐标点 P(%lf, %lf) 位于第三象限\n", x, y);
} else if (x > 0 && y < 0) {
printf("坐标点 P(%lf, %lf) 位于第四象限\n", x, y);
} else if (x == 0 && y != 0) {
printf("坐标点 P(%lf, %lf) 位于 y 轴上\n", x, y);
} else if (x != 0 && y == 0) {
printf("坐标点 P(%lf, %lf) 位于 x 轴上\n", x, y);
}
return 0;
}
运行结果
题2:
程序代码
#include <stdio.h>
// 函数原型
int fct(int n);
int main() {
int n;
// 输入 n
printf("请输入一个正整数 n:");
scanf("%d", &n);
if (n < 0) {
printf("无效的输入,n 必须是非负整数。\n");
return 1;
}
// 计算并输出 1! + 2! + 3! + ... + n!
int sum = 0;
for (int i = 1; i <= n; i++) {
sum += fct(i);
}
printf("1! + 2! + 3! + ... + %d! 的值为:%d\n", n, sum);
return 0;
}
// 计算 n 的阶乘
int fct(int n) {
int result = 1;
for (int i = 1; i <= n; i++) {
result *= i;
}
return result;
}
运行结果
题3:
程序代码
#include <stdio.h>
#include <ctype.h>
// 函数原型
void encryptString(char *s);
int main() {
char inputString[100];
// 输入字符串
printf("请输入一个字符串:\n");
fgets(inputString, sizeof(inputString), stdin);
// 对字符串进行加密
encryptString(inputString);
// 输出加密后的字符串到屏幕
printf("加密后的字符串:%s\n", inputString);
// 将加密后的字符串保存到文件
FILE *file = fopen("c:\\a.txt", "w");
if (file == NULL) {
perror("无法打开文件");
return 1;
}
fprintf(file, "%s", inputString);
fclose(file);
printf("加密后的字符串已保存到文件 c:\\a.txt 中。\n");
return 0;
}
// 对字符串进行加密
void encryptString(char *s) {
for (int i = 0; s[i] != '\0'; i++) {
// 小写字母改为大写字母
if (islower(s[i])) {
s[i] = toupper(s[i]);
}
// 数字字符‘0’、‘1’…‘8’、‘9’分别改为‘1’、‘2’… ‘9’、‘0’
else if (isdigit(s[i])) {
if (s[i] == '9') {
s[i] = '0';
} else {
s[i] = s[i] + 1;
}
}
}
}
运行结果: