C语言经典程序

1. 字符串问题

1.1 输入一行字符串,统计其中有多少单词

输入一行字符串,统计其中有多少单词,单词之间用空格符号隔开
示例:
输入:I have a pencil
输出:4

#include<stdio.h>
#include<string.h>
int total(char* str) {
	int sum = 0;
	int len = strlen(str);
	for (int i = 0; i < len; i++)
	{
		if (str[i] == ' ')
		{
			sum++;
		}
	}
	return sum;
}
int main() {
	char s[50] = "";
	printf("请输入一行字符串:\n");
	gets_s(s);
	int res = total(s);
	printf("单词个数为:%d", res+1);
	return 0;
}

1.2 字符串中提取整数(※)

假设输入的字符串中有数字和非数字字符,编写程序找出字符串中所有由连续的数字字符组成的整数,并统计共找到多少个整数。
例如:a123x456a17960?302tab6799
输出:123、456、17960、302、6799

#include<stdio.h>
int main() {
	char str[20];
	char* p = str;
	printf("请输入一个包含多段数字的字符串:\n");
	gets_s(str, 19);
	int num, count = 0;
	printf("从该字符串中找到的整数有:\n");
	while (*p)//即*p!='\0'
	{
		if (*p >= '0' && *p <= '9')//遇到数字字符
		{
			for ( num = 0; *p >= '0'&& *p<='9';p++ )//连续处理数字字符
			{
				num = num * 10 + (*p - '0');
			}
			count++;
			printf("NO %d:%d\n", count, num);
		}
		else {//遇到非数字字符
			while (*p!='\0'&&(*p<'0'||*p>'9'))//跳过所有非数字
			{
				p++;
			}
		}
	}
	printf("\n共找到%d个整数。\n", count);
	return 0;
}

总结:

  1. 数字字符的处理
  2. 连续数字的处理

1.3 字符串匹配(经典例题)

设主串数组名为S,子串数组名为T,现在要找出子串T在主串S中第一次出现的位置(下标从 0 开始)。
例如:
示例1:
输入:haystack = "sadbutsad", needle = "sad"
输出:0
解释:"sad" 在下标 0 和 6 处匹配。 第一个匹配项的下标是 0 ,所以返回 0 。
示例2:
输入:haystack = "leetcode", needle = "leeto"
输出:-1
解释:"leeto" 没有在 "leetcode" 中出现,所以返回 -1 。

#include<stdio.h>
#include<string.h>
int main() {
	char fu[] = "abcdefg", zi[] = "bc";
	int fuSize = strlen(fu), ziSize = strlen(zi);
	int p1, p2 = 0;//用于标记主串和子串的下标
	int flag = 0;//用来记录是否在主串中能找到的状态,找到了为1
	for (int i = 0; i < fuSize; i++)
	{
		p1 = i;
		for (int j = 0; j < ziSize; j++)
		{
			if (zi[j] == fu[p1++] && p1-1 < fuSize) p2 = j;
			else break;
		}
		if (p2 == ziSize-1 && zi[p2] == fu[--p1])//如果子串只有1个的情况,要考虑1个的字符是否相同
		{
			printf("子串在主串中第一次出现的位置是下标:%d", i);
			flag = 1;
			break;
		}
	}
	if (flag != 1) printf("-1");
	return 0;
}

此题可以利用KMP算法,上述为暴力解法
LeetCode母题
随想录解析

1.4 字符串匹配(查找对应字符)

在一字符串中找出某一个字符
示例:
输入:str = abc、c = a
输出:a
输入:str = abc、c = h
输出:NULL

#include<stdio.h>
#include<string.h>
char* strchr(char *s,char c) {
	int length = strlen(s);
	for (int i = 0; i < length; i++)
	{
		if (s[i] == c)
		{
			return &s[i];
		}
	}
	return NULL;
}
int main() {
	char str[] = "abc", target, * res = NULL;
	printf("请输入要查找的字符:");
	target = getchar();
	res = strchr(str, target);
	if (res != NULL)
	{
		printf("在字符串:%s中找到字符:%c",str, target);
	}
	else
	{
		printf("在字符串中找不到字符%c,返回NULL",target);
	}
	return 0;
}

注意:
1.NULL指针不能解引用
2.返回值是指针,要接收地址

2. 排列组合问题

2.1 输出不重复三位数(穷举)

输出不重复三位数
有0、1、2、3、4共5个数字 能组成多少个互不相同且无重复数字的3位数?并输出这些数
结果:
48

#include<stdio.h>
#include<string.h>
int main() {
	int sum = 0;
	for (int i = 0; i < 5; i++)
	{
		if (i == 0)
		{
			continue;
		}
		for (int j = 0; j < 5; j++)
		{
			if (j == i) {
				continue;
			}
			for (int u = 0; u < 5; u++)
			{
				if (u == j || u == i)
				{
					continue;
				}
				sum++;
				printf("%d%d%d ", i, j, u);
			}
			printf("\n");
		}
		printf("\n");
	}
	printf("一共有:%d", sum);
	return 0;
}
}

此题可以思考用回溯算法,但是代码量有点多

3. 其它

3.1 水仙花数(穷举)

编写一个程序,输出所有水仙花数,并统计共有多少个水仙花数。所谓水仙花数是指一个3位数,其各位数立方之和等于该数本身。
例如:153 = 1³ + 5³ + 3³

#include<stdio.h>
#include<string.h>
int main() {
	int num, flowerNum = 0;
	int i, j, k;
	for (int num = 100; num < 1000; num++)
	{
		i = num % 100 % 10;//取个位
		j = num % 100 / 10;//取十位
		k = num / 100;//取百位
		if (i*i*i + j*j*j + k*k*k == num)
		{
			printf("%d是水仙花数\n", num);
			flowerNum++;
		}
	}
	printf("水仙花数共有:%d个", flowerNum);
	return 0;
}

3.2 完数(穷举)

找出10000以内的自然数中的所有完数,并统计找到的完数个数。所谓完数,指它恰好等于它本身之外的因子之和。
例如:6=1+2+3,28=1+2+4+7+14

#include<stdio.h>
#include<string.h>
int main() {
	int wanshu = 0;//记录完数的个数
	int sum = 0;//记录因子和
	for (int i = 1; i < 10000; i++)
	{
		for (int j = 1; j <= i/2; j++)//因子不可能比原数的一半还大
		{
			if (i % j == 0)
			{
				sum += j;
			}
		}
		if (i == sum)
		{
			printf("%d是完数\n", i);
			wanshu++;
		}
		sum = 0;
	}
	printf("完数一共有:%d个", wanshu);
	return 0;
}

3.3 字符串查重问题(穷举)

输入一个不超过9位数的无符号整数,判断该整数中是否存在重复数字

#include<stdio.h>
#include<string.h>
int main() {
	char num[10] = "";
	printf("请输入一个不超过9位数的无符号整数:");
	gets_s(num, 9);
	int size = strlen(num);
	int flag = 0;//默认不存在重复数字
	for (int i = 0; i < size; i++)
	{
		for (int j = i+1; j < size; j++)
		{
			if ( num[i] == num[j])
			{
				flag = 1;
				break;
			}
		}
	}
	if (flag == 1)
	{
		printf("该整数中存在重复数字!");
	}
	else
	{
		printf("该整数中不存在重复数字!");
	}
	return 0;
}

4. 数组问题

4.1 在升序数组中插入数据(※)

请编写程序将一个数插入到升序数组中,使得插入后该数组仍是升序。
例如:[5,8,12,15,16,20,25,36,55],输入10
结果: [5,8,10,12,15,16,20,25,36,55]

#include<stdio.h>
#define N 10
int main() {
	int i, m, a[N] = { 5,8,12,15,16,20,25,36,55 }, * p = a + N - 2;
	printf("请输入一个待插入的整数:");
	scanf("%d", &m);
	while (p>=a)//反向扫描a[0]-a[N-2]中已经存放的N-1个升序数据
	{
		if (*p>m)
		{
			*(p + 1) = *p;//将比待插入数m大的数据往右移一位
			p--;//指针变量做自减运算
		}
		else
		{
			break;//反向扫描找到了第一个不比待插入数m大的位置
		}
	}
	*(p + 1) = m;//在结束循环的位置之右插入该数m
	printf("在升序数组中插入%d之后的结果为:\n", m);
	for ( i = 0; i < N; i++)
	{
		printf("%d ", a[i]);
	}
	printf("\n");
	return 0;
}

4.2 数组合并

将两个升序数组归并成一个新的升序数组
例如:arr1 = [1,3,5,7,9]、arr2=[2,4,6,8,10]
输出:[1,2,3,4,5,6,7,8,9,10]

#include<stdio.h>
int main() {
	int arr1[6] = { 1,3,5,7,9 ,20};
	int arr2[5] = { 2,4,6,8,10 };
	int ans[11];
	int arr1Size = 6, arr2Size = 5, i = 0, j = 0, index = 0;
	while (i < arr1Size && j < arr2Size)
	{
		if (arr1[i] < arr2[j]) {
			ans[index++] = arr1[i++];
		}
		else
		{
			ans[index++] = arr2[j++];
		}
	}
	if (i == arr1Size && j == arr2Size-1)//有剩余继续添加
	{
		ans[index] = arr2[arr2Size - 1];
	}
	else {
		ans[index] = arr1[arr1Size - 1];
	}
	for (int k = 0; k < 11; k++)
	{
		printf("%d ", ans[k]);
	}
	return 0;
}

4.3 二维数组

有4个学生,每个学生有3门课程的成绩,每门课程的学分不一样。请计算每一个学生的加权成绩

什么是加权成绩:
大学里面都是学分制的,要求加权成绩,就是把每科成绩乘以学分,然后加起来,最后除以学分之和,就是你的加权平均成绩了

#include<stdio.h>
#include<string.h>
int main() {
	int score[4][3] = { {60,80,77},{71,42,44},{99,33,55},{66,88,77} };
	int credit[3] = { 3,4,2 };
	double sum = 0;
	for (int i = 0; i < 4; i++)
	{
		for (int j = 0; j < 3; j++)
		{
			sum = sum + score[i][j] * credit[j];
		}
		printf("第%d位学生的加权平均成绩为:%.2f\n", i + 1, sum / 9);
	}
	return 0;
}

4.4 二分查找(折半查找)

编写一个函数,用折半查找法查找某数是否在给定的升序数组中
例如:
输入:arr=【1,3,5,7,9】、target = 9
输出:4
p指向一维数组,n是数组长度,key为查找关键字 找到返回元素下标,否则返回-1

#include<stdio.h>
#include<string.h>
int binary_search(int* p, int n, int key) {
	int left = 0, right = n - 1, mid;
	while (left <= right)
	{
		mid = (left + right) / 2;
		if (p[mid] > key)
		{
			right = mid - 1;
		}
		else if (p[mid] < key) {
			left = mid + 1;
		}
		else
		{
			return mid;
		}
	}
	return -1;
}
int main() {
	int data[] = { 1,2,3,4,5 };
	int res = binary_search(data, 5, 3);
	printf("%d", res);
	return 0;
}

固定模板

  • 0
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
适用于初学者    经典c程序100例==11--20 【程序11】 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月    后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? 1.程序分析: 兔子的规律为数列1,1,2,3,5,8,13,21.... 2.程序源代码: #include "stdio.h" #include "conio.h" main() { long f1,f2; int i; f1=f2=1; for(i=1;i<=20;i++) { printf("%12ld %12ld",f1,f2); if(i%2==0) printf("\n"); /*控制输出,每行四个*/ f1=f1+f2; /*前两个月加起来赋值给第三个月*/ f2=f1+f2; /*前两个月加起来赋值给第三个月*/ } getch(); } ============================================================== 【程序12】 题目:判断101-200之间有多少个素数,并输出所有素数。 1.程序分析:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,       则表明此数不是素数,反之是素数。        2.程序源代码: #include "stdio.h" #include "conio.h" #include "math.h" main() { int m,i,k,h=0,leap=1; printf("\n"); for(m=101;m<=200;m++) { k=sqrt(m+1); for(i=2;i<=k;i++) if(m%i==0) { leap=0; break; } if(leap) { printf("%-4d",m); h++; if(h%10==0) printf("\n"); } leap=1; } printf("\nThe total is %d",h); getch(); } ============================================================== 【程序13】 题目:打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数    本身。例如:153是一个“水仙花数”,因为153=1的三次方+5的三次方+3的三次方。 1.程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。 2.程序源代码: #include "stdio.h" #include "conio.h" main() { int i,j,k,n; printf("'water flower'number is:"); for(n=100;n<1000;n++) { i=n/100;/*分解出百位*/ j=n/10%10;/*分解出十位*/ k=n%10;/*分解出个位*/ if(i*100+j*10+k==i*i*i+j*j*j+k*k*k) printf("%-5d",n); } getch(); } ============================================================== 【程序14】 题目:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。 程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成: (1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。 (2)如果n<>k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,  重复执行第一步。 (3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。 2.程序源代码: /* zheng int is divided yinshu*/ #include "stdio.h" #include "conio.h" main() { int n,i; printf("\nplease input a number:\n"); scanf("%d",&n); printf("%d=",n); for(i=2;i<=n;i++) while(n!=i) { if(n%i==0) { printf("%d*",i); n=n/i; } else break; } printf("%d",n); getch(); } ============================================================== 【程序15】 题目:利用条件运算符的嵌套来完成此题:学习成绩>=90分的同学用A表示,60-89分之间的用B表示,    60分以下的用C表示。 1.程序分析:(a>b)?a:b这是条件运算符的基本例子。 2.程序源代码: #include "stdio.h" #include "conio.h" main() { int score; char grade; printf("please input a score\n"); scanf("%d",&score); grade=score>=90?'A':(score>=60?'B':'C'); printf("%d belongs to %c",score,grade); getch(); } ============================================================== 【程序16】 题目:输入两个正整数m和n,求其最大公约数和最小公倍数。 1.程序分析:利用辗除法。 2.程序源代码: #include "stdio.h" #include "conio.h" main() { int a,b,num1,num2,temp; printf("please input two numbers:\n"); scanf("%d,%d",&num1,&num2); if(num1<num2)/*交换两个数,使大数放在num1上*/ { temp=num1; num1=num2; num2=temp; } a=num1;b=num2; while(b!=0)/*利用辗除法,直到b为0为止*/ { temp=a%b; a=b; b=temp; } printf("gongyueshu:%d\n",a); printf("gongbeishu:%d\n",num1*num2/a); getch(); } ============================================================== 【程序17】 题目:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。 1.程序分析:利用while语句,条件为输入的字符不为'\n'.        2.程序源代码: #include "stdio.h" #include "conio.h" main() { char c; int letters=0,space=0,digit=0,others=0; printf("please input some characters\n"); while((c=getchar())!='\n') { if(c>='a'&&c<='z'||c>='A'&&c<='Z') letters++; else if(c==' ') space++; else if(c>='0'&&c<='9') digit++; else others++; } printf("all in all:char=%d space=%d digit=%d others=%d\n",letters, space,digit,others); getch(); } ============================================================== 【程序18】 题目:求s=a+aa+aaa+aaaa+aa...a的值,其中a是一个数字。例如2+22+222+2222+22222(此时    共有5个数相加),几个数相加有键盘控制。 1.程序分析:关键是计算出每一项的值。 2.程序源代码: #include "stdio.h" #include "conio.h" main() { int a,n,count=1; long int sn=0,tn=0; printf("please input a and n\n"); scanf("%d,%d",&a,&n); printf("a=%d,n=%d\n",a,n); while(count<=n) { tn=tn+a; sn=sn+tn; a=a*10; ++count; } printf("a+aa+...=%ld\n",sn); getch(); } ============================================================== 【程序19】 题目:一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2+3.编程    找出1000以内的所有完数。 1. 程序分析:请参照程序<--上页程序14. 2.程序源代码: #include "stdio.h" #include "conio.h" main() { static int k[10]; int i,j,n,s; for(j=2;j<1000;j++) { n=-1; s=j; for(i=1;i<j;i++) { if((j%i)==0) { n++; s=s-i; k[n]=i; } } if(s==0) { printf("%d is a wanshu",j); for(i=0;i<n;i++) printf("%d,",k[i]); printf("%d\n",k[n]); } } getch(); } ============================================================== 【程序20】 题目:一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在    第10次落地时,共经过多少米?第10次反弹多高? 1.程序分析:见下面注释 2.程序源代码: #include "stdio.h" #include "stdio.h" main() { float sn=100.0,hn=sn/2; int n; for(n=2;n<=10;n++) { sn=sn+2*hn;/*第n次落地时共经过的米数*/ hn=hn/2; /*第n次反跳高度*/ } printf("the total of road is %f\n",sn); printf("the tenth is %f meter\n",hn); getch(); }

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值