前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >C语言每日一题(8)#168. 规范化名字

C语言每日一题(8)#168. 规范化名字

作者头像
对编程一片赤诚的小吴
发布2024-01-23 14:57:48
1120
发布2024-01-23 14:57:48
举报

题目链接 #168. 规范化名字

1.思路分析

本题的思路就是输入多个字符串并将它们进行规范化,首字符大写,其他的转小写,完事后,它们进行比较排序(按字典序排序)

代码语言:javascript
复制
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<string.h>
#include<ctype.h>
#include<stdlib.h>
void dict(char* a)
{
	int i = 0;
	while (a[i])
	{
		//先判断首字符
		if (islower(a[0]))
		{
			a[0] = toupper(a[0]);
		}
		i++;
		//判断首字符后面的
		if (isupper(a[i]))
		{
			a[i] = tolower(a[i]);
		}
	}


}

void swap(char* a, char* b)
{
	char temp[100];
	strcpy(temp, a);
	strcpy(a,b);
	strcpy(b,temp);
}

int main()
{

	char str[100][100];
	int n;
	scanf("%d", &n);
	for (int i = 0; i < n; i++)//输入字符串
	{
		scanf("%s", str[i]);
	}
	for (int i = 0; i < n; i++)//规范化
	{
		dict(str[i]);
	}
	for (int i = 0; i < n; i++)
	{
		for (int j = i + 1; j < n; j++)
		{
			if (strcmp(str[i], str[j]) > 0)//strcmp函数按字典序比较两个字符串的大小,前者大于后者返回一个大于0的数。
			{
				swap(str[i], str[j]);
			}
		}
	}
	for (int i = 0; i < n; i++)
	{
		printf("%s\n", str[i]);
	}
	return 0;
}

这里我也尝试过用qsort函数进行比较,但数值一旦过大的话,程序就崩了,老铁们也可以自己去试试~

代码语言:javascript
复制
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<string.h>
#include<ctype.h>
#include<stdlib.h>
void dict(char* a)
{
	int i = 0;
	while (a[i])
	{
		//先判断首字符
		if (islower(a[0]))
		{
			a[0] = toupper(a[0]);
		}
		i++;
		//判断首字符后面的
		if (isupper(a[i]))
		{
			a[i]=tolower(a[i]);
		}
	}
	
	
}
void* cmp(void* p1, void* p2)//比较函数
{
	return strcmp((char*)p1, (char*)p2);
}

int main()
{

	char str[100][100];
	int n;
	scanf("%d", &n);
	for (int i = 0; i < n; i++)//输入字符串
	{
		scanf("%s", str[i]);
	}
	for (int i = 0; i < n; i++)//规范化
	{
		dict(str[i]);
	}
	qsort(str, n, sizeof(str[0]), cmp);//qsort实现排序
	for (int i = 0; i < n; i++)
	{
		printf("%s\n", str[i]);
	}
	return 0;
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2024-01-23,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.思路分析
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档