Maison interface Web tutoriel HTML 【TopCoder SRM 157 DIV 1】 Salary 解题报告_html/css_WEB-ITnose

【TopCoder SRM 157 DIV 1】 Salary 解题报告_html/css_WEB-ITnose

Jun 24, 2016 am 11:59 AM
div 报告 Résoudre les problèmes

本来想把原题给贴过来的,后来看到人家有版权保护,在网上搜了一下,好像也没有人在博客中贴过原题,为避免麻烦,就不copy人家原题了。

【题目大意】

公司按照每小时 wage 元给员工发工资,员工上班打卡记录一个时间,下班记录一个时间,时间格式为 "hh:mm:ss"。其中,18:00:00 到 23:59:59 和 00:00:00 到 05:59:59 之间算加班时间,工资为1.5倍。计算工资时,分钟和秒都换算成小时来计算,最终的工资取整数,舍弃后面的小数。

【函数格式】

int howMuch(vector <string> arrival, vector <string> departure, int wage)</string></string>
Copier après la connexion

【注意】

arrival和departure元素个数一样,且arrival[0]

【解题思路】

思路不难,只是时间区间判断比较麻烦,有两个时间关键点06:00:00和18:00:00。

【我的代码】

class Salary {public:	int compareTime(int hh1, int mm1, int ss1, int hh2, int mm2, int ss2) {		if (hh1 > hh2 || (hh1 == hh2 && mm1 > mm2) || (hh1 == hh2 && mm1 == mm2 && ss1 > ss2)) {			return 1;		}		if (hh1 = ss1) {			time += (ss2 - ss1) / 3600.0;		} else {			time += (ss2 + 60 - ss1) / 3600.0;			mm2 -= 1;		}		if (mm2 >= mm1) {			time += (mm2 - mm1) / 60.0;		} else {			time += (mm2 + 60 - mm1) / 60.0;			hh2 -= 1;		}		time += hh2 - hh1;		return time;	}	int howMuch(vector <string> arrival, vector <string> departure, int wage) {		int beginHour, endHour, beginMinute, endMinute, beginSecond, endSecond;		stringstream ss;		double total = 0;		for (int i = 0; i > beginHour;			ss.clear();			ss > beginMinute;			ss.clear();			ss > beginSecond;			string time2 = departure[i];			ss.clear();			ss > endHour;			ss.clear();			ss > endMinute;			ss.clear();			ss > endSecond;			if (compareTime(beginHour, beginMinute, beginSecond, 6, 0, 0) = 0						&& compareTime(endHour, endMinute, endSecond, 18, 0, 0) = 0) {					total += duringTime(beginHour, beginMinute, beginSecond, 6, 0, 0) * wage * 1.5;					total += duringTime(6, 0, 0, 18, 0, 0) * wage;					total += duringTime(18, 0, 0, endHour, endMinute, endSecond) * wage * 1.5;				}			} else if (compareTime(beginHour, beginMinute, beginSecond, 18, 0, 0) = 0) {					total += duringTime(beginHour, beginMinute, beginSecond, 18, 0, 0) * wage;					total += duringTime(18, 0, 0, endHour, endMinute, endSecond) * wage * 1.5;				}			} else {				total += duringTime(beginHour, beginMinute, beginSecond, endHour, endMinute, endSecond) * wage * 1.5;			}		}		return (int)total;	}};</string></string>
Copier après la connexion

首先是字符串转换成时分秒整数值。两个自定义函数功能分别为:比较两个时间点先后,主要是和两个关键时间点06:00:00和18:00:00比较;计算两个时间点之间的小时数。

然后一大段逻辑判断,判断员工工作时间是不是在00:00:00和06:00:00之间、06:00:00和18:00:00之间、18:00:00和00:00:00之间,还是说跨时间段。

由于基础不好,代码写得比较?嗦,欢迎大家改进。


Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment utiliser CSS pour se rendre compte qu'il manque un coin à un div Comment utiliser CSS pour se rendre compte qu'il manque un coin à un div Jan 30, 2023 am 09:23 AM

Méthode CSS pour réaliser qu'il manque un coin à un div : 1. Créez un exemple de fichier HTML et définissez un div ; 2. Définissez la couleur d'arrière-plan de la largeur et de la hauteur du div 3. Ajoutez une pseudo-classe au div qui doit être supprimé ; un coin et définissez la pseudo-classe sur Utiliser la même couleur que la couleur d'arrière-plan, puis faites-la pivoter de 45 degrés, puis positionnez-la sur le coin qui doit être supprimé.

Implémentation d'un script de navigateur de traduction de marquage de mots basé sur l'API ChatGPT Implémentation d'un script de navigateur de traduction de marquage de mots basé sur l'API ChatGPT May 01, 2023 pm 03:28 PM

Préface Récemment, il existe un script de navigateur basé sur ChatGPTAPI sur GitHub, openai-translator. En peu de temps, l'étoile a atteint 12k. En plus de prendre en charge la traduction, elle prend également en charge les fonctions de polissage et de synthèse. -ins, il utilise également le packaging tauri. Si vous avez un client de bureau, outre le fait que tauri utilise la partie rust, la partie navigateur est encore relativement simple à implémenter. Aujourd'hui, nous allons l'implémenter manuellement. L'interface fournie par openAI, par exemple, nous pouvons copier le code suivant et lancer une requête dans la console du navigateur pour terminer la traduction //Exemple constOPENAI_API_KEY="s

Quel est le modèle de boîte de division ? Quel est le modèle de boîte de division ? Oct 09, 2023 pm 05:15 PM

Le modèle de boîte div est un modèle utilisé pour la mise en page d'une page Web. Il traite les éléments d'une page Web comme des boîtes rectangulaires. Ce modèle contient quatre parties : la zone de contenu, le remplissage, la bordure et la marge. L'avantage du modèle de boîte div est qu'il peut facilement contrôler la mise en page de la page Web et l'espacement entre les éléments. En ajustant la taille de la zone de contenu, la marge intérieure, la bordure et la marge extérieure, divers effets de mise en page peuvent être obtenus. Le modèle de boîte fournit également certaines propriétés et méthodes permettant de modifier dynamiquement le style et le comportement de la boîte via CSS et JavaScript.

Quelle est la différence entre iframe et div Quelle est la différence entre iframe et div Aug 28, 2023 am 11:46 AM

La différence entre iframe et div est que iframe est principalement utilisé pour introduire du contenu externe, qui peut charger du contenu provenant d'autres sites Web ou diviser une page Web en plusieurs zones. Chaque zone a son propre contexte de navigation indépendant, tandis que div est principalement utilisé pour diviser et div. organiser le contenu. bloc pour la mise en page et le contrôle du style.

Quelles sont les différences entre div et span ? Quelles sont les différences entre div et span ? Nov 02, 2023 pm 02:29 PM

Les différences sont les suivantes : 1. div est un élément de niveau bloc et span est un élément en ligne ; 2. div occupera automatiquement une ligne, tandis que span ne sera pas automatiquement renvoyé à la ligne ; 3. div est utilisé pour envelopper des structures et des mises en page plus volumineuses ; span est utilisé pour envelopper du texte ou d'autres éléments en ligne ; 4. div peut contenir d'autres éléments de niveau bloc et des éléments en ligne, et span peut contenir d'autres éléments en ligne.

MySQL vs Oracle : comparaison des supports d'analyse et de reporting MySQL vs Oracle : comparaison des supports d'analyse et de reporting Jul 12, 2023 pm 07:37 PM

MySQL et Oracle : comparaison de la prise en charge des fonctions d'analyse et de reporting Dans le monde moderne axé sur les données, à mesure que les données d'entreprise continuent de croître, la demande de fonctions d'analyse de données et de reporting augmente également. En tant que deux systèmes de gestion de bases de données relationnelles (SGBDR) les plus populaires, MySQL et Oracle offrent des performances de support élevées à cet égard. Cet article les comparera en termes de prise en charge des fonctions d'analyse des données et de reporting, et démontrera les différences à travers des exemples de code. Tout d’abord, jetons un coup d’œil à l’analyse des données de MySQL

Cet article vous apprend à utiliser ChatGPT pour rédiger rapidement un rapport Cet article vous apprend à utiliser ChatGPT pour rédiger rapidement un rapport May 14, 2023 pm 04:04 PM

Cet article partagera l'ensemble du processus de formation de ChatGPT (la dernière version du modèle GPT-4) et de génération de rapports, et discutera des problèmes courants qui existent dans l'utilisation de ChatGPT et de la manière d'utiliser ChatGPT pour maximiser l'apprentissage et l'efficacité du travail. Voici l'ensemble du processus de génération d'un rapport de sécurité de l'IA. Sélection des sujets d'infrastructure Une sélection de sujets de haute qualité peut aider les chercheurs universitaires à déterminer rapidement le point d'entrée du rapport, guider les lecteurs pour saisir le thème principal du rapport et faire en sorte que l'ensemble du rapport présente une structure et une logique plus claires. En présentant l'arrière-plan du rapport ou en fournissant des mots-clés et un aperçu à ChatGPT, ChatGPT peut générer des sélections de sujets en quelques secondes pour référence des chercheurs. Lorsque nous posons des questions, nous pouvons demander à ChatGPT de générer plusieurs choix de sujets en même temps, ce qui aide

Conseils jQuery : Maîtrisez comment ajouter des balises dans les divs Conseils jQuery : Maîtrisez comment ajouter des balises dans les divs Feb 23, 2024 pm 01:51 PM

Titre : jQuery Conseils : Maîtriser la méthode d'ajout de balises aux divs En développement web, nous rencontrons souvent des situations où nous devons ajouter dynamiquement des balises à la page. Vous pouvez utiliser jQuery pour manipuler facilement les éléments DOM et obtenir des fonctions d'ajout d'étiquettes rapides. Cet article expliquera comment utiliser jQuery pour ajouter des balises dans les divs et joindra des exemples de code spécifiques. 1. Travail de préparation Avant d'utiliser jQuery, vous devez introduire la bibliothèque jQuery dans la page. Vous pouvez l'introduire via un lien CDN ou la télécharger sur cette page.

See all articles