2021-03-13

HDU 1083(二分图匹配\匈牙利算法)

题目链接

Consider a group of N students and P courses. Each student visits zero, one or more than one courses. Your task is to determine whether it is possible to form a committee of exactly P students that satisfies simultaneously the conditions:

. every student in the committee represents a different course (a student can represent a course if he/she visits that course)

. each course has a representative in the committee

Your program should read sets of data from a text file. The first line of the input file contains the number of the data sets. Each data set is presented in the following format:

P N
Count1 Student1 1 Student1 2 … Student1 Count1
Count2 Student2 1 Student2 2 … Student2 Count2

CountP StudentP 1 StudentP 2 … StudentP CountP

The first line in each data set contains two positive integers separated by one blank: P (1 <= P <= 100) - the number of courses and N (1 <= N <= 300) - the number of students. The next P lines describe in sequence of the courses . from course 1 to course P, each line describing a course. The description of course i is a line that starts with an integer Count i (0 <= Count i <= N) representing the number of students visiting course i. Next, after a blank, you’ll find the Count i students, visiting the course, each two consecutive separated by one blank. Students are numbered with the positive integers from 1 to N.

There are no blank lines between consecutive sets of data. Input data are correct.

The result of the program is on the standard output. For each input data set the program prints on a single line “YES” if it is possible to form a committee and “NO” otherwise. There should not be any leading blanks at the start of the line.

An example of program input and output:

Sample Input

2
3 3
3 1 2 3
2 1 2
1 1
3 3
2 1 3
2 1 3
1 1

Sample Output

YES
NO

Code

#include<iostream>
#include<cstring>
using namespace std;
int MAP[520][520];//第i节课和第j个学生的联系
int vis[520];//作为标记是否被访问
int link[520];//第i节课被第link[i]个学生选中
int P,N;//p节课,n个学生
bool find(int x)
{
    for(int i=1;i<=N;i++)
    {
        if (MAP[x][i]&&vis[i]==0)//第x节课和第i个学生之间有联系,在这里就是第i个学生选了第x节课,可以看main()函数里面的实现||第i节课没有被访问
        {
            vis[i]=1;//进行了访问,进行标记
            if (link[i]==0||find(link[i]))//第i个学生没有选课或者第i个学生选的第link[i]节课可以换成其他学生
            {
                link[i]=x;//对第i个学生选的第link[i]节课进行更新
                return true;//第x节课可以被学生匹配到,就返回true
            }
        }
    }
    return false;
}
int main()
{
    int T;
    cin>>T;
    while(T--)
    {
        memset(MAP,0,sizeof(MAP));//每次进行新的一组测试数据时都要情况MAP[][]数组
        cin>>P>>N;//按照题目要求输入P和N;P节课和N个学生
        for(int i=1;i<=P;i++)
        {
            int temp;
            cin>>temp;//有temp个学生选了第i节课
            for(int j=1;j<=temp;j++)
            {
                int y;
                cin>>y;
                MAP[i][y]=1;//第y个学生选了第i节课
            }
        }
        int ans=0;//定义变量并赋初值为零
        memset(link,0,sizeof (link));//情况link[]数组
        for(int i=1;i<=P;i++)
        {
            memset(vis,0,sizeof (vis));//每次循环要把vis数组情况
            if (find(i)) ans++;//如果第i节课可以被选到就对ans++;
        }

        if (ans==P) cout<<"YES\n";//所有课程全部都有学生选,那么就满足题目要求
        else cout<<"NO\n";
    }

    return 0;
}

具体的我已经写在注释里面了,这也算是比较简单的一道二分图匹配吧;

有问题请多多指教,我也是小白一个;

<think>好的,用户想比较两个日期字符串的大小,比如'2021-01-03'和'2021-03-04'。首先,我需要考虑如何正确解析这些字符串并转换成可比较的格式。日期字符串的格式是yyyy-MM-dd,这在编程中很常见,但不同的编程语言可能有不同的处理方法。 用户可能用的是哪种语言呢?问题中引用了Java的引用,比如SimpleDateFormat,所以可能用户使用的是Java。不过,也可能用户对其他语言的方法感兴趣,比如Python或JavaScript。我需要先确定主要方法,再提到其他语言的例子。 首先,在Java中,比较日期字符串的方法是将字符串转换为Date对象,然后使用compareTo方法。或者,使用SimpleDateFormat将字符串解析成Date对象后再比较。另外,用户提到的引用[1]和[2]都提到了字符串比较,如果格式正确的话,直接按字符串比较是否可行?比如,如果日期字符串的格式是yyyy-MM-dd,并且每个部分都是两位补零的话,那么按字典序比较字符串是否有效?例如'2021-01-03'和'2021-03-04',直接比较字符串的话,前者的月份是01,后者是03,所以字符串比较会正确识别前者更小。但需要确认格式是否正确,比如月份和日期是否补零。如果用户输入的日期字符串是标准化的,那么直接比较可能有效,如引用[2]提到的。 但更可靠的方法还是将字符串转换为日期对象再比较,这样可以避免格式不一致的问题。例如,在Java中,使用SimpleDateFormat.parse()将字符串转为Date对象,然后比较两个Date对象的时间戳。或者在Python中,使用datetime模块的strptime方法解析字符串为datetime对象,再比较这些对象。 另外,用户可能需要处理不同格式的情况,但题目中的例子都是相同的格式,所以可能不需要考虑格式转换的问题。但为了代码的健壮性,应该先验证字符串是否符合预期格式。 现在需要分步骤说明:首先解析字符串为日期对象,然后比较。给出具体代码示例,比如Java和Python的。同时,提到直接字符串比较的条件和注意事项。 需要注意的是,直接字符串比较只有在格式严格一致且各部分补零的情况下才有效。例如,月份必须是两位,如03而不是3,否则像'2021-3-04'这样的字符串直接比较就会出错,因为3和03的字典序不同。所以,虽然引用[2]提到可以比较,但前提是格式正确。需要提醒用户这一点。 总结回答步骤: 1. 确认日期字符串的格式是否符合标准(yyyy-MM-dd,补零)。 2. 如果格式正确,可以直接字符串比较。 3. 否则,转换为日期对象再比较。 4. 提供不同编程语言的示例,如Java、Python、JavaScript。 5. 强调注意事项,如格式必须一致,补零的重要性。 现在检查引用内容,引用[1]提到使用SimpleDateFormat的format方法将日期转化为字符串再比较,但这里用户是要比较输入的字符串,可能直接转换后的比较是否需要?或者用户可能误解了引用的内容。不过引用[2]明确说明在格式正确的情况下,可以直接比较字符串。所以需要结合这两种方法。 可能用户的问题更倾向于如何正确转换,所以重点放在解析字符串为日期对象的方法上,同时提到直接比较的条件。因此,回答应该分两种方法:直接比较(条件严格)和转换为对象比较(更可靠)。 在代码示例中,Java使用SimpleDateFormat或LocalDate(Java 8及以上),Python使用datetime,JavaScript使用Date对象。例如: Java示例(使用SimpleDateFormat): 解析两个字符串为Date对象,然后使用compareTo或before/after方法。 Python示例: 使用datetime.strptime解析字符串为datetime对象,然后直接比较。 JavaScript示例: 将字符串转换为Date对象,再比较时间戳。 同时,提醒异常处理,比如捕获解析异常,以防格式错误。 最后,相关问题可能涉及日期格式转换、不同语言的处理方法、如何处理不同格式的日期比较,或者性能上的考虑。</think>要比较两个格式为$yyyy-MM-dd$的日期字符串(例如$'2021-01-03'$和$'2021-03-04'$),可通过以下方法实现: --- ### 方法一:直接字符串比较(仅适用于标准化格式) 若字符串满足以下条件: 1. 年份、月份、日期均补零(如`03`而非`3`) 2. 格式严格统一为$yyyy-MM-dd$ 可直接按**字典序**比较字符串: ```python date1 = '2021-01-03' date2 = '2021-03-04' print(date1 < date2) # 输出 True ``` --- ### 方法二:转换为日期对象(推荐) 通过编程语言内置的日期解析工具,将字符串转换为日期对象后再比较: #### **Java 示例** ```java import java.text.SimpleDateFormat; import java.util.Date; public class DateCompare { public static void main(String[] args) { SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); try { Date date1 = sdf.parse("2021-01-03"); Date date2 = sdf.parse("2021-03-04"); System.out.println(date1.before(date2)); // 输出 true } catch (Exception e) { e.printStackTrace(); } } } ``` #### **Python 示例** ```python from datetime import datetime date_str1 = '2021-01-03' date_str2 = '2021-03-04' date1 = datetime.strptime(date_str1, "%Y-%m-%d") date2 = datetime.strptime(date_str2, "%Y-%m-%d") print(date1 < date2) # 输出 True ``` #### **JavaScript 示例** ```javascript const date1 = new Date('2021-01-03'); const date2 = new Date('2021-03-04'); console.log(date1 < date2); // 输出 true ``` --- ### 注意事项 1. **格式一致性**:确保字符串格式与解析格式完全匹配[^2]。 2. **异常处理**:转换时需捕获可能的格式错误(如`2021-13-32`)。 3. **时区问题**:部分语言(如JavaScript)的`Date`对象会受时区影响,建议使用UTC时间。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值